@zuplo/cli 6.71.22 → 6.71.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (89) hide show
  1. package/node_modules/@posthog/core/dist/posthog-core-stateless.d.ts +5 -0
  2. package/node_modules/@posthog/core/dist/posthog-core-stateless.d.ts.map +1 -1
  3. package/node_modules/@posthog/core/dist/posthog-core-stateless.js +50 -10
  4. package/node_modules/@posthog/core/dist/posthog-core-stateless.mjs +47 -10
  5. package/node_modules/@posthog/core/dist/posthog-core.d.ts +2 -2
  6. package/node_modules/@posthog/core/dist/posthog-core.d.ts.map +1 -1
  7. package/node_modules/@posthog/core/dist/posthog-core.js +10 -6
  8. package/node_modules/@posthog/core/dist/posthog-core.mjs +11 -7
  9. package/node_modules/@posthog/core/dist/testing/PostHogCoreTestClient.d.ts +1 -0
  10. package/node_modules/@posthog/core/dist/testing/PostHogCoreTestClient.d.ts.map +1 -1
  11. package/node_modules/@posthog/core/dist/testing/PostHogCoreTestClient.js +3 -0
  12. package/node_modules/@posthog/core/dist/testing/PostHogCoreTestClient.mjs +3 -0
  13. package/node_modules/@posthog/core/dist/utils/promise-queue.d.ts +3 -0
  14. package/node_modules/@posthog/core/dist/utils/promise-queue.d.ts.map +1 -1
  15. package/node_modules/@posthog/core/dist/utils/promise-queue.js +15 -3
  16. package/node_modules/@posthog/core/dist/utils/promise-queue.mjs +15 -3
  17. package/node_modules/@posthog/core/package.json +1 -1
  18. package/node_modules/@posthog/core/src/posthog-core-stateless.ts +80 -14
  19. package/node_modules/@posthog/core/src/posthog-core.ts +18 -7
  20. package/node_modules/@posthog/core/src/testing/PostHogCoreTestClient.ts +4 -0
  21. package/node_modules/@posthog/core/src/utils/promise-queue.ts +17 -4
  22. package/node_modules/@posthog/types/dist/posthog.d.ts +12 -0
  23. package/node_modules/@posthog/types/dist/posthog.d.ts.map +1 -1
  24. package/node_modules/@posthog/types/package.json +1 -1
  25. package/node_modules/@posthog/types/src/posthog.ts +13 -0
  26. package/node_modules/@types/node/README.md +1 -1
  27. package/node_modules/@types/node/buffer.d.ts +64 -25
  28. package/node_modules/@types/node/crypto.d.ts +18 -5
  29. package/node_modules/@types/node/diagnostics_channel.d.ts +237 -3
  30. package/node_modules/@types/node/dns.d.ts +1 -1
  31. package/node_modules/@types/node/ffi.d.ts +486 -0
  32. package/node_modules/@types/node/fs/promises.d.ts +3 -0
  33. package/node_modules/@types/node/fs.d.ts +21 -6
  34. package/node_modules/@types/node/http.d.ts +25 -0
  35. package/node_modules/@types/node/index.d.ts +1 -0
  36. package/node_modules/@types/node/package.json +2 -2
  37. package/node_modules/@types/node/process.d.ts +14 -1
  38. package/node_modules/@types/node/quic.d.ts +92 -11
  39. package/node_modules/@types/node/sqlite.d.ts +55 -0
  40. package/node_modules/@types/node/stream/iter.d.ts +150 -0
  41. package/node_modules/@types/node/stream.d.ts +32 -0
  42. package/node_modules/@types/node/test.d.ts +112 -2
  43. package/node_modules/@types/node/ts5.6/index.d.ts +1 -0
  44. package/node_modules/@types/node/ts5.7/index.d.ts +1 -0
  45. package/node_modules/@types/node/util.d.ts +19 -2
  46. package/node_modules/@types/node/v8.d.ts +84 -2
  47. package/node_modules/@types/node/worker_threads.d.ts +8 -7
  48. package/node_modules/@zuplo/core/package.json +1 -1
  49. package/node_modules/@zuplo/graphql/out/esm/index.js +11 -11
  50. package/node_modules/@zuplo/graphql/out/esm/index.js.map +1 -1
  51. package/node_modules/@zuplo/graphql/package.json +1 -1
  52. package/node_modules/@zuplo/openapi-tools/package.json +1 -1
  53. package/node_modules/@zuplo/otel/package.json +1 -1
  54. package/node_modules/@zuplo/runtime/out/esm/{chunk-54PA7VDV.js → chunk-4QJJMELB.js} +1 -1
  55. package/node_modules/@zuplo/runtime/out/esm/{chunk-54PA7VDV.js.map → chunk-4QJJMELB.js.map} +1 -1
  56. package/node_modules/@zuplo/runtime/out/esm/chunk-5CYWMN74.js +402 -0
  57. package/node_modules/@zuplo/runtime/out/esm/chunk-5CYWMN74.js.map +1 -0
  58. package/node_modules/@zuplo/runtime/out/esm/index.js +1 -1
  59. package/node_modules/@zuplo/runtime/out/esm/index.js.map +1 -1
  60. package/node_modules/@zuplo/runtime/out/esm/mcp-gateway/index.js +7 -7
  61. package/node_modules/@zuplo/runtime/out/esm/mcp-gateway/index.js.map +1 -1
  62. package/node_modules/@zuplo/runtime/out/esm/mocks/index.js +1 -1
  63. package/node_modules/@zuplo/runtime/out/types/index.d.ts +109 -19
  64. package/node_modules/@zuplo/runtime/out/types/mcp-gateway/index.d.ts +33 -7
  65. package/node_modules/@zuplo/runtime/package.json +1 -1
  66. package/node_modules/iconv-lite/encodings/sbcs-data.js +2 -0
  67. package/node_modules/iconv-lite/encodings/utf32.js +10 -3
  68. package/node_modules/iconv-lite/package.json +2 -2
  69. package/node_modules/iconv-lite/types/encodings.d.ts +2 -0
  70. package/node_modules/protobufjs/dist/light/protobuf.js +2 -2
  71. package/node_modules/protobufjs/dist/light/protobuf.min.js +2 -2
  72. package/node_modules/protobufjs/dist/minimal/protobuf.js +2 -2
  73. package/node_modules/protobufjs/dist/minimal/protobuf.min.js +2 -2
  74. package/node_modules/protobufjs/dist/protobuf.js +5 -2
  75. package/node_modules/protobufjs/dist/protobuf.js.map +1 -1
  76. package/node_modules/protobufjs/dist/protobuf.min.js +3 -3
  77. package/node_modules/protobufjs/dist/protobuf.min.js.map +1 -1
  78. package/node_modules/protobufjs/package.json +1 -1
  79. package/node_modules/protobufjs/src/parse.js +3 -0
  80. package/node_modules/toad-cache/README.md +10 -9
  81. package/node_modules/toad-cache/dist/toad-cache.cjs +139 -139
  82. package/node_modules/toad-cache/dist/toad-cache.mjs +136 -140
  83. package/node_modules/toad-cache/package.json +8 -8
  84. package/node_modules/toad-cache/toad-cache.d.cts +20 -14
  85. package/node_modules/toad-cache/toad-cache.d.ts +18 -14
  86. package/package.json +6 -6
  87. package/node_modules/@zuplo/runtime/out/esm/chunk-36XLJ4X6.js +0 -389
  88. package/node_modules/@zuplo/runtime/out/esm/chunk-36XLJ4X6.js.map +0 -1
  89. /package/node_modules/@zuplo/runtime/out/esm/{chunk-36XLJ4X6.js.LEGAL.txt → chunk-5CYWMN74.js.LEGAL.txt} +0 -0
@@ -22,11 +22,11 @@
22
22
  * DEALINGS IN THE SOFTWARE.
23
23
  *--------------------------------------------------------------------------------------------*/
24
24
 
25
- import{$b as Ac,$c as Co,Ab as q,Ac as yo,Ad as x,Bb as Qn,Bc as _o,Bd as Yt,Cb as He,Cc as I,Cd as xc,Db as eo,Dc as de,Dd as Tc,Eb as Be,Ec as Ge,Fb as g,Fc as N,Gb as Le,Gc as O,Hb as Ne,Hc as wo,Ib as _e,Ic as J,Jb as we,Jc as Ro,Kb as Bt,Kc as be,Lb as to,Lc as Ar,Mb as ne,Mc as $t,N as Jn,Nb as ro,Nc as kr,O as l,Ob as ce,Oc as Zt,P as Gn,Pb as R,Pc as ut,Q as Sr,Qb as Lt,Qc as Fe,R as se,Rb as L,Rc as bo,S as Fn,Sb as Re,Sc as ue,T as _,Tb as _c,Tc as xr,U as ye,Ub as wc,Uc as Tr,V as Ht,Vb as Rc,Vc as Io,W as $n,Wb as bc,Wc as Kt,X as Zn,Xb as Ic,Xc as Ur,Y as Kn,Yb as Sc,Yc as Pr,Z as d,Zb as Cc,Zc as So,_ as K,_b as vc,_c as M,ac as kc,ad as vo,bc as no,bd as Er,cc as oo,cd as Ao,dc as io,dd as ko,ea as Wn,ec as Nt,ed as Or,fc as Cr,fd as xo,gc as Jt,gd as Te,h as Z,hc as Gt,hd as To,ic as st,id as lt,jc as ao,jd as Uo,kc as so,kd as Wt,lc as co,ld as pt,mc as ct,md as Po,nc as uo,nd as Eo,oc as Je,od as Oo,p as xe,pc as lo,pd as qo,q as Bn,qc as vr,qd as Mo,rc as po,rd as Do,s as Ln,sc as dt,sd as jo,tc as Ft,td as Vt,uc as mo,ud as zo,vc as fo,vd as Ho,w as Nn,wb as Vn,wc as ho,wd as b,xb as W,xc as go,xd as v,y as zt,yb as Yn,yc as te,yd as G,zb as Xn,zc as H,zd as le}from"../chunk-36XLJ4X6.js";import"../chunk-4MNJC7E2.js";import{a as S}from"../chunk-54PA7VDV.js";import{$ as ee,a as n,aa as h,ba as B,ca as Hn,da as jt}from"../chunk-DSZS6PZJ.js";K();function Uc(e){let t=Gt.safeParse(e);return t.success?t.data.id:void 0}n(Uc,"parseJsonRpcRequestId");function Bo(e){if(e!==void 0)try{let t=JSON.parse(new TextDecoder().decode(e));return Uc(t)}catch{return}}n(Bo,"readJsonRpcRequestIdFromBody");function Xt(e){return ao.parse({jsonrpc:Jt,...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(Xt,"jsonRpcErrorResponse");function Lo(e){return new co([so.parse({mode:"url",message:e.message,elicitationId:e.elicitationId,url:e.url})],e.message)}n(Lo,"urlElicitationRequiredError");var Qt=d.record(d.string(),d.unknown()),Pc=d.record(d.string(),d.unknown()),Ec=d.object({name:d.string().min(1),description:d.string().min(1).optional(),annotations:Pc.optional(),_meta:Qt.optional()}).strict(),Oc=d.object({name:d.string().min(1),description:d.string().min(1).optional(),_meta:Qt.optional()}).strict(),qc=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:Qt.optional()}).strict(),Mc=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:Qt.optional()}).strict(),Dc=d.array(d.union([d.string(),Ec])),jc=d.array(d.union([d.string(),Oc])),zc=d.array(d.union([d.string(),qc])),Hc=d.array(d.union([d.string(),Mc])),Bc=d.object({tools:Dc.optional(),prompts:jc.optional(),resources:zc.optional(),resourceTemplates:Hc.optional()}).strict(),Mr=[{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 Lc(e,t){return Yn(Bc,e,`MCP capability filter policy "${t}"`)}n(Lc,"parseMcpCapabilityFilterOptions");function F(e){return e!==null&&typeof e=="object"&&!Array.isArray(e)}n(F,"isRecord");function Nc(e,t){if(!F(e))return;let r=e[t];return typeof r=="string"?r:void 0}n(Nc,"readParamString");function Dr(e){let t=e.id;return typeof t=="string"||typeof t=="number"||t===null?t:void 0}n(Dr,"readRequestId");function Fo(e){return e===void 0?void 0:JSON.stringify(e)}n(Fo,"requestIdKey");function Jc(e){let t={};for(let r of Mr){let o=e[r.option];if(o===void 0)continue;let i=new Map;for(let a of o){let c=Zc(a,r.itemProperty);c!==void 0&&i.set(c.key,c)}t[r.option]=i}return t}n(Jc,"buildProjectionMaps");function jr(e){return Mr.find(t=>t.listMethod===e)}n(jr,"findListRule");function Gc(e){return e.requests.some(t=>{if(!F(t))return!1;let r=jr(t.method);return r!==void 0&&e.projectionMaps[r.option]!==void 0})}n(Gc,"shouldFilterListResponses");function Fc(e){for(let t of Mr){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=Nc(e.request.params,o.paramProperty);if(i!==void 0&&!r.has(i))return{id:Dr(e.request)}}}}n(Fc,"findDisallowedDirectAccess");function $c(e){return Response.json(Xt({id:e,error:{code:st.MethodNotFound,message:"Method not found"}}))}n($c,"methodNotFoundResponse");function Zc(e,t){if(typeof e=="string")return{key:e,overlay:{}};if(!F(e))return;let r=e[t];if(typeof r=="string")return{key:r,overlay:e}}n(Zc,"buildProjection");function No(e){let t=e.base[e.property],r=e.overlay[e.property];return F(r)?F(t)?{...t,...r}:r:t}n(No,"mergeRecordProperty");function Kc(e,t){let r={...e,...t.overlay},o=No({base:e,overlay:t.overlay,property:"annotations"});o!==void 0&&(r.annotations=o);let i=No({base:e,overlay:t.overlay,property:"_meta"});return i!==void 0&&(r._meta=i),r}n(Kc,"applyProjection");function Jo(e,t,r){if(!F(e))return e;let o=e.result;if(!F(o))return e;let i=o[t.resultProperty];return!Array.isArray(i)||!i.every(a=>F(a)&&typeof a[t.itemProperty]=="string")?e:{...e,result:{...o,[t.resultProperty]:i.flatMap(a=>{if(!F(a))return[];let c=a[t.itemProperty];if(typeof c!="string")return[];let s=r.get(c);return s===void 0?[]:[Kc(a,s)]})}}}n(Jo,"filterAndProjectItems");function Wc(e){let t=new Map;if(!Array.isArray(e))return t;for(let r of e){if(!F(r))continue;let o=jr(r.method),i=Dr(r),a=Fo(i);o!==void 0&&a!==void 0&&t.set(a,o)}return t}n(Wc,"buildListRulesByResponseId");function Vc(e){if(Array.isArray(e.responseBody)){let o=Wc(e.requestBody);return o.size===0?e.responseBody:e.responseBody.map(i=>{if(!F(i)||"error"in i)return i;let a=Fo(Dr(i)),c=a===void 0?void 0:o.get(a),s=c===void 0?void 0:e.projectionMaps[c.option];return c===void 0||s===void 0?i:Jo(i,c,s)})}if(!F(e.requestBody)||!F(e.responseBody)||"error"in e.responseBody)return e.responseBody;let t=jr(e.requestBody.method),r=t===void 0?void 0:e.projectionMaps[t.option];return t===void 0||r===void 0?e.responseBody:Jo(e.responseBody,t,r)}n(Vc,"filterJsonRpcResponse");async function Go(e){return e.clone().json()}n(Go,"readJson");function Yc(e){return e.headers.get("content-type")?.includes("json")??!1}n(Yc,"isJsonResponse");var qr=class extends zt{static{n(this,"McpCapabilityFilterInboundPolicy")}#e;constructor(t,r){let o=Lc(t,r);super(o,r),this.#e=Jc(o)}async handler(t,r){Z("policy.inbound.mcp-capability-filter");let o;try{o=await Go(t)}catch{return t}let i=Array.isArray(o)?o:[o];for(let a of i){if(!F(a))continue;let c=Fc({request:a,projectionMaps:this.#e});if(c!==void 0)return $c(c.id)}return Gc({requests:i,projectionMaps:this.#e})&&r.addResponseSendingHook(async a=>{if(!Yc(a))return a;let c;try{c=await Go(a)}catch{return a}let s=Vc({requestBody:o,responseBody:c,projectionMaps:this.#e});if(s===c)return a;let u=new Headers(a.headers);return u.delete("content-length"),new Response(JSON.stringify(s),{status:a.status,statusText:a.statusText,headers:u})}),t}};var zr;zr=globalThis.crypto;async function Xc(e){return(await zr).getRandomValues(new Uint8Array(e))}n(Xc,"getRandomValues");async function Qc(e){let t="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-._~",r=Math.pow(2,8)-Math.pow(2,8)%t.length,o="";for(;o.length<e;){let i=await Xc(e-o.length);for(let a of i)a<r&&(o+=t[a%t.length])}return o}n(Qc,"random");async function ed(e){return await Qc(e)}n(ed,"generateVerifier");async function td(e){let t=await(await zr).subtle.digest("SHA-256",new TextEncoder().encode(e));return btoa(String.fromCharCode(...new Uint8Array(t))).replace(/\//g,"_").replace(/\+/g,"-").replace(/=/g,"")}n(td,"generateChallenge");async function Hr(e){if(e||(e=43),e<43||e>128)throw`Expected a length between 43 and 128. Received ${e}.`;let t=await ed(e),r=await td(t);return{code_verifier:t,code_challenge:r}}n(Hr,"pkceChallenge");K();var j=Gn().superRefine((e,t)=>{if(!URL.canParse(e))return t.addIssue({code:Zn.custom,message:"URL must be parseable",fatal:!0}),Jn}).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"}),er=Ht({resource:l().url(),authorization_servers:_(j).optional(),jwks_uri:l().url().optional(),scopes_supported:_(l()).optional(),bearer_methods_supported:_(l()).optional(),resource_signing_alg_values_supported:_(l()).optional(),resource_name:l().optional(),resource_documentation:l().optional(),resource_policy_uri:l().url().optional(),resource_tos_uri:l().url().optional(),tls_client_certificate_bound_access_tokens:se().optional(),authorization_details_types_supported:_(l()).optional(),dpop_signing_alg_values_supported:_(l()).optional(),dpop_bound_access_tokens_required:se().optional()}),mt=Ht({issuer:l(),authorization_endpoint:j,token_endpoint:j,registration_endpoint:j.optional(),scopes_supported:_(l()).optional(),response_types_supported:_(l()),response_modes_supported:_(l()).optional(),grant_types_supported:_(l()).optional(),token_endpoint_auth_methods_supported:_(l()).optional(),token_endpoint_auth_signing_alg_values_supported:_(l()).optional(),service_documentation:j.optional(),revocation_endpoint:j.optional(),revocation_endpoint_auth_methods_supported:_(l()).optional(),revocation_endpoint_auth_signing_alg_values_supported:_(l()).optional(),introspection_endpoint:l().optional(),introspection_endpoint_auth_methods_supported:_(l()).optional(),introspection_endpoint_auth_signing_alg_values_supported:_(l()).optional(),code_challenge_methods_supported:_(l()).optional(),client_id_metadata_document_supported:se().optional()}),rd=Ht({issuer:l(),authorization_endpoint:j,token_endpoint:j,userinfo_endpoint:j.optional(),jwks_uri:j,registration_endpoint:j.optional(),scopes_supported:_(l()).optional(),response_types_supported:_(l()),response_modes_supported:_(l()).optional(),grant_types_supported:_(l()).optional(),acr_values_supported:_(l()).optional(),subject_types_supported:_(l()),id_token_signing_alg_values_supported:_(l()),id_token_encryption_alg_values_supported:_(l()).optional(),id_token_encryption_enc_values_supported:_(l()).optional(),userinfo_signing_alg_values_supported:_(l()).optional(),userinfo_encryption_alg_values_supported:_(l()).optional(),userinfo_encryption_enc_values_supported:_(l()).optional(),request_object_signing_alg_values_supported:_(l()).optional(),request_object_encryption_alg_values_supported:_(l()).optional(),request_object_encryption_enc_values_supported:_(l()).optional(),token_endpoint_auth_methods_supported:_(l()).optional(),token_endpoint_auth_signing_alg_values_supported:_(l()).optional(),display_values_supported:_(l()).optional(),claim_types_supported:_(l()).optional(),claims_supported:_(l()).optional(),service_documentation:l().optional(),claims_locales_supported:_(l()).optional(),ui_locales_supported:_(l()).optional(),claims_parameter_supported:se().optional(),request_parameter_supported:se().optional(),request_uri_parameter_supported:se().optional(),require_request_uri_registration:se().optional(),op_policy_uri:j.optional(),op_tos_uri:j.optional(),client_id_metadata_document_supported:se().optional()}),tr=ye({...rd.shape,...mt.pick({code_challenge_methods_supported:!0}).shape}),$e=ye({access_token:l(),id_token:l().optional(),token_type:l(),expires_in:Kn.number().optional(),scope:l().optional(),refresh_token:l().optional()}).strip(),Zo=ye({error:l(),error_description:l().optional(),error_uri:l().optional()}),$o=j.optional().or($n("").transform(()=>{})),nd=ye({redirect_uris:_(j),token_endpoint_auth_method:l().optional(),grant_types:_(l()).optional(),response_types:_(l()).optional(),client_name:l().optional(),client_uri:j.optional(),logo_uri:$o,scope:l().optional(),contacts:_(l()).optional(),tos_uri:$o,policy_uri:l().optional(),jwks_uri:j.optional(),jwks:Fn().optional(),software_id:l().optional(),software_version:l().optional(),software_statement:l().optional()}).strip(),rr=ye({client_id:l(),client_secret:l().optional(),client_id_issued_at:Sr().optional(),client_secret_expires_at:Sr().optional()}).strip(),ft=nd.merge(rr),Zh=ye({error:l(),error_description:l().optional()}).strip(),Kh=ye({token:l(),token_type_hint:l().optional()}).strip();function Ko(e){let t=typeof e=="string"?new URL(e):new URL(e.href);return t.hash="",t}n(Ko,"resourceUrlFromServerUrl");function Wo({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(Wo,"checkResourceAllowed");var A=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}},ht=class extends A{static{n(this,"InvalidRequestError")}};ht.errorCode="invalid_request";var Ue=class extends A{static{n(this,"InvalidClientError")}};Ue.errorCode="invalid_client";var Pe=class extends A{static{n(this,"InvalidGrantError")}};Pe.errorCode="invalid_grant";var Ee=class extends A{static{n(this,"UnauthorizedClientError")}};Ee.errorCode="unauthorized_client";var gt=class extends A{static{n(this,"UnsupportedGrantTypeError")}};gt.errorCode="unsupported_grant_type";var yt=class extends A{static{n(this,"InvalidScopeError")}};yt.errorCode="invalid_scope";var _t=class extends A{static{n(this,"AccessDeniedError")}};_t.errorCode="access_denied";var pe=class extends A{static{n(this,"ServerError")}};pe.errorCode="server_error";var wt=class extends A{static{n(this,"TemporarilyUnavailableError")}};wt.errorCode="temporarily_unavailable";var Rt=class extends A{static{n(this,"UnsupportedResponseTypeError")}};Rt.errorCode="unsupported_response_type";var bt=class extends A{static{n(this,"UnsupportedTokenTypeError")}};bt.errorCode="unsupported_token_type";var It=class extends A{static{n(this,"InvalidTokenError")}};It.errorCode="invalid_token";var St=class extends A{static{n(this,"MethodNotAllowedError")}};St.errorCode="method_not_allowed";var Ct=class extends A{static{n(this,"TooManyRequestsError")}};Ct.errorCode="too_many_requests";var Oe=class extends A{static{n(this,"InvalidClientMetadataError")}};Oe.errorCode="invalid_client_metadata";var vt=class extends A{static{n(this,"InsufficientScopeError")}};vt.errorCode="insufficient_scope";var At=class extends A{static{n(this,"InvalidTargetError")}};At.errorCode="invalid_target";var Vo={[ht.errorCode]:ht,[Ue.errorCode]:Ue,[Pe.errorCode]:Pe,[Ee.errorCode]:Ee,[gt.errorCode]:gt,[yt.errorCode]:yt,[_t.errorCode]:_t,[pe.errorCode]:pe,[wt.errorCode]:wt,[Rt.errorCode]:Rt,[bt.errorCode]:bt,[It.errorCode]:It,[St.errorCode]:St,[Ct.errorCode]:Ct,[Oe.errorCode]:Oe,[vt.errorCode]:vt,[At.errorCode]:At};function od(e){return["client_secret_basic","client_secret_post","none"].includes(e)}n(od,"isClientAuthMethod");var Br="code",Lr="S256";function id(e,t){let r=e.client_secret!==void 0;return"token_endpoint_auth_method"in e&&e.token_endpoint_auth_method&&od(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(id,"selectClientAuthMethod");function ad(e,t,r,o){let{client_id:i,client_secret:a}=t;switch(e){case"client_secret_basic":sd(i,a,r);return;case"client_secret_post":cd(i,a,o);return;case"none":dd(i,o);return;default:throw new Error(`Unsupported client authentication method: ${e}`)}}n(ad,"applyClientAuthentication");function sd(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(sd,"applyBasicAuth");function cd(e,t,r){r.set("client_id",e),t&&r.set("client_secret",t)}n(cd,"applyPostAuth");function dd(e,t){t.set("client_id",e)}n(dd,"applyPublicAuth");async function Xo(e){let t=e instanceof Response?e.status:void 0,r=e instanceof Response?await e.text():e;try{let o=Zo.parse(JSON.parse(r)),{error:i,error_description:a,error_uri:c}=o,s=Vo[i]||pe;return new s(a||"",c)}catch(o){let i=`${t?`HTTP ${t}: `:""}Invalid OAuth error response: ${o}. Raw body: ${r}`;return new pe(i)}}n(Xo,"parseErrorResponse");async function Gr(e,t){try{return await Nr(e,t)}catch(r){if(r instanceof Ue||r instanceof Ee)return await e.invalidateCredentials?.("all"),await Nr(e,t);if(r instanceof Pe)return await e.invalidateCredentials?.("tokens"),await Nr(e,t);throw r}}n(Gr,"auth");async function Nr(e,{serverUrl:t,authorizationCode:r,scope:o,resourceMetadataUrl:i,fetchFn:a}){let c=await e.discoveryState?.(),s,u,p,f=i;if(!f&&c?.resourceMetadataUrl&&(f=new URL(c.resourceMetadataUrl)),c?.authorizationServerUrl){if(u=c.authorizationServerUrl,s=c.resourceMetadata,p=c.authorizationServerMetadata??await ti(u,{fetchFn:a}),!s)try{s=await ei(t,{resourceMetadataUrl:f},a)}catch{}(p!==c.authorizationServerMetadata||s!==c.resourceMetadata)&&await e.saveDiscoveryState?.({authorizationServerUrl:String(u),resourceMetadataUrl:f?.toString(),resourceMetadata:s,authorizationServerMetadata:p})}else{let E=await hd(t,{resourceMetadataUrl:f,fetchFn:a});u=E.authorizationServerUrl,p=E.authorizationServerMetadata,s=E.resourceMetadata,await e.saveDiscoveryState?.({authorizationServerUrl:String(u),resourceMetadataUrl:f?.toString(),resourceMetadata:s,authorizationServerMetadata:p})}let w=await ud(t,e,s),U=o||s?.scopes_supported?.join(" ")||e.clientMetadata.scope,y=await Promise.resolve(e.clientInformation());if(!y){if(r!==void 0)throw new Error("Existing OAuth client information is required when exchanging an authorization code");let E=p?.client_id_metadata_document_supported===!0,D=e.clientMetadataUrl;if(D&&!Fr(D))throw new Oe(`clientMetadataUrl must be a valid HTTPS URL with a non-root pathname, got: ${D}`);if(E&&D)y={client_id:D},await e.saveClientInformation?.(y);else{if(!e.saveClientInformation)throw new Error("OAuth client information must be saveable for dynamic registration");let zn=await Rd(u,{metadata:p,clientMetadata:e.clientMetadata,scope:U,fetchFn:a});await e.saveClientInformation(zn),y=zn}}let P=!e.redirectUrl;if(r!==void 0||P){let E=await wd(e,u,{metadata:p,resource:w,authorizationCode:r,fetchFn:a});return await e.saveTokens(E),"AUTHORIZED"}let k=await e.tokens();if(k?.refresh_token)try{let E=await _d(u,{metadata:p,clientInformation:y,refreshToken:k.refresh_token,resource:w,addClientAuthentication:e.addClientAuthentication,fetchFn:a});return await e.saveTokens(E),"AUTHORIZED"}catch(E){if(!(!(E instanceof A)||E instanceof pe))throw E}let z=e.state?await e.state():void 0,{authorizationUrl:ze,codeVerifier:Q}=await gd(u,{metadata:p,clientInformation:y,state:z,redirectUrl:e.redirectUrl,scope:U,resource:w});return await e.saveCodeVerifier(Q),await e.redirectToAuthorization(ze),"REDIRECT"}n(Nr,"authInternal");function Fr(e){if(!e)return!1;try{let t=new URL(e);return t.protocol==="https:"&&t.pathname!=="/"}catch{return!1}}n(Fr,"isHttpsUrl");async function ud(e,t,r){let o=Ko(e);if(t.validateResourceURL)return await t.validateResourceURL(o,r?.resource);if(r){if(!Wo({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(ud,"selectResourceURL");function Qo(e){let t=e.headers.get("WWW-Authenticate");if(!t)return{};let[r,o]=t.split(" ");if(r.toLowerCase()!=="bearer"||!o)return{};let i=Jr(e,"resource_metadata")||void 0,a;if(i)try{a=new URL(i)}catch{}let c=Jr(e,"scope")||void 0,s=Jr(e,"error")||void 0;return{resourceMetadataUrl:a,scope:c,error:s}}n(Qo,"extractWWWAuthenticateParams");function Jr(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(Jr,"extractFieldFromWwwAuth");async function ei(e,t,r=fetch){let o=await md(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 er.parse(await o.json())}n(ei,"discoverOAuthProtectedResourceMetadata");async function $r(e,t,r=fetch){try{return await r(e,{headers:t})}catch(o){if(o instanceof TypeError)return t?$r(e,void 0,r):void 0;throw o}}n($r,"fetchWithCorsRetry");function ld(e,t="",r={}){return t.endsWith("/")&&(t=t.slice(0,-1)),r.prependPathname?`${t}/.well-known/${e}`:`/.well-known/${e}${t}`}n(ld,"buildWellKnownPath");async function Yo(e,t,r=fetch){return await $r(e,{"MCP-Protocol-Version":t},r)}n(Yo,"tryMetadataDiscovery");function pd(e,t){return!e||e.status>=400&&e.status<500&&t!=="/"}n(pd,"shouldAttemptFallback");async function md(e,t,r,o){let i=new URL(e),a=o?.protocolVersion??Cr,c;if(o?.metadataUrl)c=new URL(o.metadataUrl);else{let u=ld(t,i.pathname);c=new URL(u,o?.metadataServerUrl??i),c.search=i.search}let s=await Yo(c,a,r);if(!o?.metadataUrl&&pd(s,i.pathname)){let u=new URL(`/.well-known/${t}`,i);s=await Yo(u,a,r)}return s}n(md,"discoverMetadataWithFallback");function fd(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(fd,"buildDiscoveryUrls");async function ti(e,{fetchFn:t=fetch,protocolVersion:r=Cr}={}){let o={"MCP-Protocol-Version":r,Accept:"application/json"},i=fd(e);for(let{url:a,type:c}of i){let s=await $r(a,o,t);if(s){if(!s.ok){if(await s.body?.cancel(),s.status>=400&&s.status<500)continue;throw new Error(`HTTP ${s.status} trying to load ${c==="oauth"?"OAuth":"OpenID provider"} metadata from ${a}`)}return c==="oauth"?mt.parse(await s.json()):tr.parse(await s.json())}}}n(ti,"discoverAuthorizationServerMetadata");async function hd(e,t){let r,o;try{r=await ei(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 ti(o,{fetchFn:t?.fetchFn});return{authorizationServerUrl:o,authorizationServerMetadata:i,resourceMetadata:r}}n(hd,"discoverOAuthServerInfo");async function gd(e,{metadata:t,clientInformation:r,redirectUrl:o,scope:i,state:a,resource:c}){let s;if(t){if(s=new URL(t.authorization_endpoint),!t.response_types_supported.includes(Br))throw new Error(`Incompatible auth server: does not support response type ${Br}`);if(t.code_challenge_methods_supported&&!t.code_challenge_methods_supported.includes(Lr))throw new Error(`Incompatible auth server: does not support code challenge method ${Lr}`)}else s=new URL("/authorize",e);let u=await Hr(),p=u.code_verifier,f=u.code_challenge;return s.searchParams.set("response_type",Br),s.searchParams.set("client_id",r.client_id),s.searchParams.set("code_challenge",f),s.searchParams.set("code_challenge_method",Lr),s.searchParams.set("redirect_uri",String(o)),a&&s.searchParams.set("state",a),i&&s.searchParams.set("scope",i),i?.includes("offline_access")&&s.searchParams.append("prompt","consent"),c&&s.searchParams.set("resource",c.href),{authorizationUrl:s,codeVerifier:p}}n(gd,"startAuthorization");function yd(e,t,r){return new URLSearchParams({grant_type:"authorization_code",code:e,code_verifier:t,redirect_uri:String(r)})}n(yd,"prepareAuthorizationCodeRequest");async function ri(e,{metadata:t,tokenRequestParams:r,clientInformation:o,addClientAuthentication:i,resource:a,fetchFn:c}){let s=t?.token_endpoint?new URL(t.token_endpoint):new URL("/token",e),u=new Headers({"Content-Type":"application/x-www-form-urlencoded",Accept:"application/json"});if(a&&r.set("resource",a.href),i)await i(u,r,s,t);else if(o){let f=t?.token_endpoint_auth_methods_supported??[],w=id(o,f);ad(w,o,u,r)}let p=await(c??fetch)(s,{method:"POST",headers:u,body:r});if(!p.ok)throw await Xo(p);return $e.parse(await p.json())}n(ri,"executeTokenRequest");async function _d(e,{metadata:t,clientInformation:r,refreshToken:o,resource:i,addClientAuthentication:a,fetchFn:c}){let s=new URLSearchParams({grant_type:"refresh_token",refresh_token:o}),u=await ri(e,{metadata:t,tokenRequestParams:s,clientInformation:r,addClientAuthentication:a,resource:i,fetchFn:c});return{refresh_token:o,...u}}n(_d,"refreshAuthorization");async function wd(e,t,{metadata:r,resource:o,authorizationCode:i,fetchFn:a}={}){let c=e.clientMetadata.scope,s;if(e.prepareTokenRequest&&(s=await e.prepareTokenRequest(c)),!s){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 p=await e.codeVerifier();s=yd(i,p,e.redirectUrl)}let u=await e.clientInformation();return ri(t,{metadata:r,tokenRequestParams:s,clientInformation:u??void 0,addClientAuthentication:e.addClientAuthentication,resource:o,fetchFn:a})}n(wd,"fetchToken");async function Rd(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 c=await(i??fetch)(a,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...r,...o!==void 0?{scope:o}:{}})});if(!c.ok)throw await Xo(c);return ft.parse(await c.json())}n(Rd,"registerClient");var Zr="zuplo.com",bd=new Set(["co.jp","co.kr","co.nz","co.uk","com.au","com.br","com.cn","com.mx","com.sg","co.in"]),Id=[".example.test",".example.com",".example.org",".invalid",".localhost",".test"];function ni(e){return`https://www.google.com/s2/favicons?domain=${e}&sz=128`}n(ni,"s2FaviconHref");function Sd(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(Sd,"strictFaviconHref");var nr=ni(Zr);function Kr(e){let t=e.toLowerCase();return t===Zr||t==="zuplo.app"||t==="zuplo.dev"||t.endsWith(".zuplo.app")||t.endsWith(".zuplo.dev")?ni(Zr):Sd(e)}n(Kr,"resolveIconHref");function Cd(e){try{return new URL(`http://${e}`).hostname}catch{return e}}n(Cd,"hostnameFromHost");function vd(e){return e==="localhost"||e.includes(":")||/^\d{1,3}(?:\.\d{1,3}){3}$/.test(e)}n(vd,"isLocalOrAddressHost");function Ad(e){let t=Cd(e).toLowerCase().replace(/\.$/,"");if(vd(t)||Id.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=bd.has(o)?3:2;return r.slice(-i).join(".")}n(Ad,"inferFaviconDomain");function Wr(e){return{src:Kr(Ad(e)),mimeType:"image/png",sizes:["128x128"]}}n(Wr,"resolveMcpFaviconIcon");function or(e){try{return Wr(new URL(e).host)}catch{return}}n(or,"resolveMcpFaviconIconFromUrl");function Ie(e){let t=te().connectionsById.get(e);if(!t)throw new B(`Unknown upstream server "${e}". Check the route's MCP upstream policy and ensure policies.json declares a matching upstream connection.`);return{displayName:t.displayName,description:t.description,serverInfo:t.serverInfo,transport:{baseUrl:t.mcpUrl,resourceMetadataUrl:t.protectedResourceMetadataUrl}}}n(Ie,"getUpstreamServerConfig");function ir(e){let t=te().connectionsById.get(e.upstreamServerId);if(!t||t.authProfileId!==e.authProfileId)throw new B(`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.authConfig}n(ir,"getUpstreamAuthConfig");function Ze(e,t){let r=ir({upstreamServerId:e,authProfileId:t});if(r.mode!=="shared-oauth"&&r.mode!=="user-oauth")throw new B(`Upstream server "${e}" does not use upstream OAuth. Select authMode "shared-oauth" or "user-oauth" before starting an upstream OAuth connection flow.`);return r.oauth}n(Ze,"requireUpstreamOAuthConfig");function oi(e,t){let r=ir({upstreamServerId:e,authProfileId:t});if(r.mode!=="id-jag")throw new B(`Upstream server "${e}" does not use upstream ID-JAG. Select authMode "id-jag" before requesting an upstream XAA token exchange.`);return r.idJag}n(oi,"requireUpstreamIdJagConfig");function ii(e,t){if(!t)return;if(t.aborted){e.abort(t.reason);return}let r=n(()=>e.abort(t.reason),"abort");return t.addEventListener("abort",r,{once:!0}),()=>t.removeEventListener("abort",r)}n(ii,"mergeAbortSignals");async function kd(e){try{await e.cancel()}catch{}}n(kd,"cancelReader");async function ar(e,t){if(!e)return new Uint8Array;let r=e.getReader(),o=[],i=0,a=await r.read();for(;!a.done;){let u=a.value;if(i+=u.byteLength,i>t.maxBytes)throw await kd(r),t.createLimitError();o.push(u),a=await r.read()}let c=new Uint8Array(i),s=0;for(let u of o)c.set(u,s),s+=u.byteLength;return c}n(ar,"readBoundedByteStream");var xd=2,Td=1024*1024,Ud=1e4,Pd=new Set([301,302,303,307,308]),Ed=["authorization","proxy-authorization","cookie","cookie2"];function Vr(e){return typeof e=="string"?e:e instanceof URL?e.toString():e.url}n(Vr,"readRequestUrl");function Ke(e,t){return t?.method!==void 0?t.method.toUpperCase():e instanceof Request?e.method.toUpperCase():"GET"}n(Ke,"readRequestMethod");function Od(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 new h({message:"Outbound response exceeded the maximum allowed size.",extensionMembers:{[g]:r}})}n(Od,"assertContentLengthWithinLimit");async function qd(e,t,r){return Od(e,t,r),ar(e.body,{maxBytes:t,createLimitError:n(()=>new h({message:"Outbound response exceeded the maximum allowed size.",extensionMembers:{[g]:r}}),"createLimitError")})}n(qd,"readBoundedResponseBody");function Md(e,t){let r=new ArrayBuffer(t.byteLength);return new Uint8Array(r).set(t),new Response(r,{status:e.status,statusText:e.statusText,headers:e.headers})}n(Md,"responseFromBufferedBody");function Dd(e,t){if(!Pd.has(e.status))return;let r=e.headers.get("location");if(r)return new URL(r,t).toString()}n(Dd,"resolveRedirectUrl");function ai(e,t){try{return t.validateUrl(e)}catch(r){throw new h({message:"Outbound URL was not allowed.",extensionMembers:{[g]:t.problemCode}},{cause:r})}}n(ai,"validateOutboundUrl");function jd(e,t){throw e instanceof h&&Bt(e.extensionMembers?.[g])?e:new h({message:"Outbound fetch failed.",extensionMembers:{[g]:t}},{cause:e})}n(jd,"normalizeFetchError");function kt(e,t){if(e===void 0)return;let r={event:t.event,code:t.problemCode,method:t.method};if(t.host!==void 0&&(r.host=t.host),t.extra!==void 0)for(let[o,i]of Object.entries(t.extra))i!==void 0&&(r[o]=i);t.error!==void 0&&N(r,"error",t.error),e.log.warn(r,"Outbound HTTP exchange rejected")}n(kt,"logOutboundFailure");async function zd(e,t,r,o,i,a,c){let s=Ke(r,o);try{return await t(r,o)}catch(u){let p=u instanceof DOMException&&u.name==="AbortError";kt(e,{event:p?"outbound_fetch_aborted":"outbound_fetch_failed",problemCode:i,method:s,host:O(a),error:u,extra:{abortReason:c()}}),jd(u,i)}}n(zd,"fetchWithNormalizedError");function Hd(e){if(e.redirects>=e.maxRedirects)throw new h({message:"Outbound redirects exceeded the maximum allowed depth.",extensionMembers:{[g]:e.problemCode}});if(e.method!=="GET"&&e.method!=="HEAD")throw new h({message:"Outbound redirect after a non-idempotent request was blocked.",extensionMembers:{[g]:e.problemCode}})}n(Hd,"assertRedirectAllowed");function Bd(e,t){let r=new Headers(e);for(let o of Ed)r.delete(o);for(let o of t)r.delete(o);return r}n(Bd,"stripCrossOriginHeaders");function Ld(e,t,r,o,i){let a={...e,method:t,redirect:"manual",signal:r};return o&&(a.headers=Bd(e.headers,i)),a}n(Ld,"buildRedirectInit");function Nd(e,t,r){let o={...t,redirect:"manual",signal:r};return o.headers===void 0&&e instanceof Request&&(o.headers=e.headers),o}n(Nd,"buildInitialRequestInit");function Jd(e){let t=Ke(e.currentInput,e.currentInit);Hd({redirects:e.redirects,maxRedirects:e.maxRedirects,method:t,problemCode:e.problemCode});let r=ai(e.redirectUrl,{problemCode:e.problemCode,validateUrl:e.validateUrl}),o=new URL(e.currentUrl),i=r.origin!==o.origin,a=r.toString();return{currentInput:a,currentUrl:a,currentInit:Ld(e.currentInit,t,e.signal,i,e.additionalCrossOriginStrippedHeaders),redirects:e.redirects+1}}n(Jd,"followRedirect");async function Yr(e,t,r){let o=r.problemCode??"invalid_request",i=r.maxRedirects??xd,a=r.maxResponseBytes??Td,c=r.timeoutMs??Ud,s=r.fetchImpl??fetch,u=r.additionalCrossOriginStrippedHeaders??[],p=r.context,f=new AbortController,w=ii(f,t.signal),U=!1,y=setTimeout(()=>{U=!0,f.abort()},c),P=e,k=Nd(e,t,f.signal),z;try{z=ai(Vr(e),{problemCode:o,validateUrl:r.validateUrl}).toString()}catch(Q){throw kt(p,{event:"outbound_url_blocked",problemCode:o,method:Ke(e,t),host:O(Vr(e)),error:Q}),clearTimeout(y),w?.(),Q}let ze=0;try{for(;;){let Q=await zd(p,s,P,k,o,z,()=>U?`timeout_after_${c}ms`:void 0),E=Dd(Q,z);if(E!==void 0)try{let D=Jd({currentInput:P,currentInit:k,currentUrl:z,redirectUrl:E,redirects:ze,maxRedirects:i,problemCode:o,validateUrl:r.validateUrl,signal:f.signal,additionalCrossOriginStrippedHeaders:u});P=D.currentInput,k=D.currentInit,z=D.currentUrl,ze=D.redirects;continue}catch(D){throw kt(p,{event:"outbound_redirect_blocked",problemCode:o,method:Ke(P,k),host:O(z),error:D,extra:{redirects:ze,maxRedirects:i,redirectTargetHost:O(E)}}),D}try{return Md(Q,await qd(Q,a,o))}catch(D){throw kt(p,{event:"outbound_response_size_exceeded",problemCode:o,method:Ke(P,k),host:O(z),error:D,extra:{maxResponseBytes:a,status:Q.status}}),D}}}finally{clearTimeout(y),w?.()}}n(Yr,"runSafeOutboundExchange");async function xt(e,t,r){let o=await Yr(e,t,r);try{return{response:o,json:await o.clone().json()}}catch(i){throw kt(r.context,{event:"outbound_json_parse_failed",problemCode:r.problemCode??"invalid_request",method:Ke(e,t),host:O(Vr(e)),error:i,extra:{status:o.status,contentType:o.headers.get("content-type")??void 0}}),new h({message:"Outbound JSON response could not be parsed.",extensionMembers:{[g]:r.problemCode??"invalid_request"}},{cause:i})}}n(xt,"runSafeOutboundJsonExchange");function si(e,t={},r={}){return Yr(e,t,{...r,validateUrl:lt})}n(si,"fetchConfiguredOutbound");function ci(e,t={},r={}){return xt(e,t,{...r,validateUrl:lt})}n(ci,"fetchConfiguredOutboundJson");function sr(e,t={},r={}){return xt(e,t,{...r,validateUrl:Uo})}n(sr,"fetchIdentityProviderJson");function di(e,t={},r={}){return xt(e,t,{...r,validateUrl:Wt})}n(di,"fetchCimdClientMetadataJson");function ui(e,t={},r={}){return xt(e,t,{...r,validateUrl:pt})}n(ui,"fetchCimdClientJwksJson");K();import{errors as gi,jwtVerify as yi,SignJWT as _i}from"jose";var $="zuplo-mcp-gateway",V=$,Y="HS256";import{base64url as Gd}from"jose";var Fd=new TextEncoder,$d="MCP gateway could not initialize secure key material.",Zd=32,li=new Map,pi=new Map,Kd;function Wd(){return Kd??Hn.instance.authPrivateKey}n(Wd,"readAuthPrivateKey");function mi(e){return new ee($d,e===void 0?void 0:{cause:e})}n(mi,"createGeneratedKeyMaterialError");function fi(e,t){let r=Gd.decode(t);if(r.byteLength!==Zd)throw new Error(`Generated deployment auth key ${e} is invalid.`);return r}n(fi,"decodeJwkKeyField");function Vd(e){let t=Wd();if(!t)throw mi();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=fi("d",r.d);fi("x",r.x);let i=Fd.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 mi(r)}}n(Vd,"decodeGeneratedKeyMaterial");function Yd(e){let t=li.get(e);return t||(t=Vd(e),li.set(e,t)),t}n(Yd,"getMasterKeyMaterial");async function ie(e){let t=pi.get(e.purpose);if(t!==void 0)return t;let r=await e.derive(Yd(e.keyMaterialPurpose));return pi.set(e.purpose,r),r}n(ie,"readCachedDerivedKey");var Xd="SHA-256",Qd=32,eu="zuplo-mcp-gateway:",tu=new TextEncoder,hi=new WeakMap;async function Se(e,t){let r=hi.get(e);r||(r=new Map,hi.set(e,r));let o=r.get(t);if(o)return o;let i=await ru(e,t);return r.set(t,i),i}n(Se,"deriveGatewaySigningKey");async function ru(e,t){let r=G(e),o=await crypto.subtle.importKey("raw",r,{name:"HKDF"},!1,["deriveBits"]),i=tu.encode(`${eu}${t}`),a=await crypto.subtle.deriveBits({name:"HKDF",hash:Xd,salt:new Uint8Array,info:G(i)},o,Qd*8);return new Uint8Array(a)}n(ru,"hkdfExpand");var wi=900,nu=900,ou=po.extend({id:Mo}),iu=ou.extend({exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),Ri=vr.extend({id:Do,purpose:d.literal("browser_connect")}),au=vr.extend({purpose:d.literal("browser_connect")}),su=Ri.extend({exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),bi=wi*1e3;async function Ii(){return ie({purpose:"oauth-state",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>Se(e,"oauth-state"),"derive")})}n(Ii,"getOAuthStateKey");async function Si(){return ie({purpose:"browser-connect",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>Se(e,"browser-connect"),"derive")})}n(Si,"getBrowserConnectKey");async function Ci(e){let t=Math.floor(Date.now()/1e3)+wi;return new _i(e).setProtectedHeader({alg:Y,typ:"JWT"}).setIssuer($).setAudience(V).setIssuedAt().setExpirationTime(t).sign(await Ii())}n(Ci,"signOAuthState");async function cr(e){try{let{payload:t}=await yi(e,await Ii(),{algorithms:[Y],issuer:$,audience:V});return iu.parse(t)}catch(t){throw t instanceof gi.JWTExpired?new h({message:"OAuth state has expired",extensionMembers:{[g]:"oauth_state_expired"}},{cause:t}):new h({message:"OAuth state could not be verified",extensionMembers:{[g]:"oauth_state_invalid"}},{cause:t})}}n(cr,"verifyOAuthState");async function vi(e){let t=Math.floor(Date.now()/1e3)+nu,r=au.parse(e),o=Ri.parse({...r,id:Ho()});return new _i(o).setProtectedHeader({alg:Y,typ:"JWT"}).setIssuer($).setAudience(V).setIssuedAt().setExpirationTime(t).sign(await Si())}n(vi,"signBrowserConnectTicket");async function Ai(e){try{let{payload:t}=await yi(e,await Si(),{algorithms:[Y],issuer:$,audience:V});return su.parse(t)}catch(t){throw t instanceof gi.JWTExpired?new h({message:"Browser connect ticket has expired",extensionMembers:{[g]:"oauth_state_expired"}},{cause:t}):new h({message:"Browser connect ticket could not be verified",extensionMembers:{[g]:"oauth_state_invalid"}},{cause:t})}}n(Ai,"verifyBrowserConnectTicket");async function ki(e){if((await b().consumeBrowserConnectTicket({id:e.id,expiresAt:I(new Date(e.exp*1e3)),now:I(new Date)})).kind==="consumed")throw new h({message:"Browser connect ticket has already been used",extensionMembers:{[g]:"oauth_state_reused"}})}n(ki,"consumeBrowserConnectTicket");function cu(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(cu,"buildConnectRequiredMessage");async function du(e){let t=q(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 vi({...dt(e),purpose:"browser_connect"})),r.toString()}n(du,"buildGatewayBrowserTicketUrl");function uu(e){return H().actionPath(`/auth/connections/${encodeURIComponent(e)}/connect`)}n(uu,"buildGatewayConnectPath");async function Xr(e){return du({...e,path:uu(e.upstreamServerId),redirect:!0})}n(Xr,"buildGatewayConnectUrl");async function dr(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 Xr(t),message:cu(e.upstreamDisplayName,e.subject,e.requiresReconsent),nextAction:"redirect"}}n(dr,"buildRedirectConnectRequiredResponse");function xi(e){return lu({...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(xi,"buildAdminConnectRequiredResponse");function lu(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(lu,"buildAdminSetupRequiredResponse");var Ti=12;async function Ui(e){let t=await crypto.subtle.digest("SHA-256",G(new TextEncoder().encode(e)));return Array.from(new Uint8Array(t)).map(r=>r.toString(16).padStart(2,"0")).join("")}n(Ui,"sha256Hex");async function We(e){if(e)return(await Ui(e)).slice(0,Ti)}n(We,"fingerprintSecret");async function Ve(e){let t=JSON.stringify([e.owner.mode,e.owner.mode==="user"?e.owner.subjectId:"",e.upstreamServerId,e.authProfileId]);return(await Ui(t)).slice(0,Ti)}n(Ve,"fingerprintConnectionIdentity");function Tt(e){return e?e.status!=="active"?"inactive":e.encryptedAccessToken?e.expiresAt&&new Date(e.expiresAt).getTime()<=Date.now()?"expired":"usable":"no_access_token":"no_connection"}n(Tt,"describeAccessTokenState");K();var Pi=new Set(["client_id","code_challenge","code_challenge_method","display","login_hint","nonce","prompt","redirect_uri","response_mode","response_type","state"]);function pu(e,t){return e&&e.length>0?e.join(t):void 0}n(pu,"joinOAuthScopes");function mu(e){if(e?.authorization_endpoint===void 0)return e;let t=new URL(e.authorization_endpoint);for(let r of Pi)t.searchParams.delete(r);return{...e,authorization_endpoint:t.toString()}}n(mu,"sanitizeAuthorizationServerMetadata");function Ei(e){let t=mu(e.authorizationServerMetadata);return t===e.authorizationServerMetadata?e:{...e,authorizationServerMetadata:t}}n(Ei,"sanitizeOAuthDiscoveryState");function Oi(e){let t=new URL(e);for(let r of Pi){let o=t.searchParams.getAll(r);o.length<=1||(t.searchParams.delete(r),t.searchParams.set(r,o.at(-1)??""))}return t}n(Oi,"dedupeSingletonAuthorizationRequestParams");function ur(e){let t=new URL(e);return W(t)&&Vn(t.hostname)!=="localhost"&&(t.hostname="localhost"),t}n(ur,"normalizeLoopbackOAuthRedirectUri");function qi(e){return pu(e.state?.resourceMetadata?.scopes_supported,e.delimiter)}n(qi,"readProtectedResourceMetadataScope");function fu(e){return`Zuplo MCP Gateway - ${e}`}n(fu,"buildGatewayOAuthClientName");function hu(e,t){return e&&e.length>0?e.join(t):void 0}n(hu,"joinOAuthScopeList");function gu(e){if(e.clientRegistration.mode!=="auto")return hu(e.scopes,e.scopeDelimiter)}n(gu,"readPublicClientMetadataScope");function Qr(e){return new URL(H().actionPath(`/.well-known/oauth-client/${encodeURIComponent(e.upstreamServerId)}`),e.origin).toString()}n(Qr,"buildOAuthClientMetadataDocumentUrl");function en(e){let t=Ie(e.upstreamServerId);return{client_name:fu(t.displayName),client_uri:new URL("/",e.origin).toString(),redirect_uris:[e.redirectUri],grant_types:["authorization_code","refresh_token"],response_types:["code"],application_type:"web",...e.scope===void 0?{}:{scope:e.scope},token_endpoint_auth_method:"none"}}n(en,"buildGatewayOAuthClientMetadata");function Mi(e,t,r){let o=Ze(t,r),i=gu(o);return{client_id:Qr({origin:e,upstreamServerId:t}),...en({origin:e,upstreamServerId:t,redirectUri:ur(new URL(o.redirectPath,e)).toString(),scope:i})}}n(Mi,"buildOAuthClientMetadataDocument");K();import{base64url as Ce}from"jose";var yu="SHA-256",Ye="AES-GCM",_u=12,rn="zuplo-secret",nn=1,Di="generated:auth_private_key:token-encryption",wu=d.object({version:d.literal(nn),keyId:d.literal(Di),algorithm:d.literal(Ye),iv:d.string().min(1),ciphertext:d.string().min(1)}).strict();async function tn(){return ie({purpose:"token-encryption",keyMaterialPurpose:"token-encryption",derive:n(async e=>{let t=await crypto.subtle.digest(yu,G(e));return crypto.subtle.importKey("raw",t,{name:Ye},!1,["encrypt","decrypt"])},"derive")})}n(tn,"getEncryptionKey");function ji(e){return G(new TextEncoder().encode(`${rn}:v${e.version}:${e.keyId}`))}n(ji,"getAssociatedData");function Ru(e){return`${rn}:v${e.version}:${Ce.encode(new TextEncoder().encode(JSON.stringify(e)))}`}n(Ru,"encodeEnvelope");function bu(e){let t=`${rn}:v${nn}:`;if(!e.startsWith(t))return;let r=e.slice(t.length),o=new TextDecoder().decode(Ce.decode(r));return wu.parse(JSON.parse(o))}n(bu,"decodeEnvelope");async function me(e){let t=await tn(),r=crypto.getRandomValues(new Uint8Array(_u)),o={version:nn,keyId:Di},i=await crypto.subtle.encrypt({name:Ye,iv:r,additionalData:ji(o)},t,new TextEncoder().encode(e));return Ru({...o,algorithm:Ye,iv:Ce.encode(r),ciphertext:Ce.encode(new Uint8Array(i))})}n(me,"encryptSecret");async function ve(e){let t=bu(e);if(t){let c=await tn(),s=await crypto.subtle.decrypt({name:Ye,iv:G(Ce.decode(t.iv)),additionalData:ji(t)},c,G(Ce.decode(t.ciphertext)));return new TextDecoder().decode(s)}let[r,o]=e.split(".");if(!r||!o)throw new ee("Encrypted payload is malformed");let i=await tn(),a=await crypto.subtle.decrypt({name:Ye,iv:G(Ce.decode(r))},i,G(Ce.decode(o)));return new TextDecoder().decode(a)}n(ve,"decryptSecret");var Iu=d.union([ft,rr]),Su=d.object({authorizationServerUrl:d.url(),resourceMetadataUrl:d.url().optional(),resourceMetadata:er.optional(),authorizationServerMetadata:d.union([mt,tr]).optional()}).passthrough(),Cu="Bearer",vu="__zuplo_refresh_only_upstream_access_token__";function Au(e){return e?e.split(/[,\s]+/).filter(Boolean):[]}n(Au,"splitScopes");function ku(e){return Be.parse(e)}n(ku,"parsePkceCodeVerifier");function xu(e){if(typeof e.expires_in=="number")return I(new Date(Date.now()+e.expires_in*1e3))}n(xu,"readTokenExpiry");async function Tu(e){if(e!==void 0)return me(JSON.stringify(e))}n(Tu,"encryptJson");async function Uu(e,t){if(!e)return;let r=await ve(e);try{return t.parse(JSON.parse(r))}catch(o){throw new h({message:"Stored upstream OAuth JSON state is invalid.",extensionMembers:{[g]:"oauth_state_invalid"}},{cause:o})}}n(Uu,"decryptJson");function Pu(e,t){return"redirect_uris"in e?e.redirect_uris.includes(t):!0}n(Pu,"clientInformationAllowsRedirectUri");function Eu(e){return e.clientMetadataUrl===void 0?"redirect_uris"in e.clientInformation:"redirect_uris"in e.clientInformation||e.clientInformation.client_id===e.clientMetadataUrl}n(Eu,"clientInformationMatchesCurrentClientMetadataUrl");function Ou(e){return e.clientMetadataUrl!==void 0&&!("redirect_uris"in e.clientInformation)&&e.clientInformation.client_id===e.clientMetadataUrl}n(Ou,"isUrlBasedClientInformation");function qu(e,t){return t===void 0?e:{...e,scope:t}}n(qu,"applyOAuthClientMetadataScope");function Mu(e,t){return qi({state:e,delimiter:t})}n(Mu,"readResourceMetadataScope");function Du(e,t){return e&&e.length>0?e.join(t):void 0}n(Du,"joinOAuthScopeList");function ju(e){let t;if(e.registration.tokenEndpointAuthMethod!=="none"&&(t=e.registration.clientSecret,!t))throw new B(`Manual OAuth registration for upstream "${e.upstreamServerId}" requires clientSecret. Set the env var that backs the client secret or use tokenEndpointAuthMethod "none".`);return ft.parse({...e.clientMetadata,client_id:e.registration.clientId,token_endpoint_auth_method:e.registration.tokenEndpointAuthMethod,...t===void 0?{}:{client_secret:t}})}n(ju,"buildManualOAuthClientInformation");function zu(e,t){let r=Qr({origin:new URL(t).origin,upstreamServerId:e});return Fr(r)?r:void 0}n(zu,"buildClientMetadataUrl");function Hu(e){for(let t of e)if(t!==void 0)return t}n(Hu,"firstDefined");function Bu(e){let t=Ze(e.target.upstreamServerId,e.target.authProfileId),r=Du(t.scopes,t.scopeDelimiter),o=en({origin:new URL(e.redirectUri).origin,upstreamServerId:e.target.upstreamServerId,redirectUri:e.redirectUri,scope:r});if(t.clientRegistration.mode==="manual")return{clientMetadata:o,configuredScope:r,scopeDelimiter:t.scopeDelimiter,configuredClientInformation:ju({clientMetadata:o,registration:t.clientRegistration,upstreamServerId:e.target.upstreamServerId})};let i=zu(e.target.upstreamServerId,e.redirectUri);return i===void 0?{clientMetadata:o,configuredScope:r,scopeDelimiter:t.scopeDelimiter}:{clientMetadata:o,configuredScope:r,scopeDelimiter:t.scopeDelimiter,clientMetadataUrl:i}}n(Bu,"buildInitialOAuthClientSetup");function Lu(e,t){if(t===void 0)return Hu([e.pendingState?.encryptedClientInformation,e.connectionMetadata?.encryptedClientInformation,e.connection?.metadata?.encryptedClientInformation])}n(Lu,"readEncryptedClientInformation");var qe=class{static{n(this,"UpstreamOAuthProvider")}clientMetadataUrl;target;redirectUriValue;returnOrigin;clientMetadataValue;configuredScope;scopeDelimiter;configuredClientInformation;challengeScope;inferredScope;authorizationUrlValue;connection;pendingState;encryptedClientInformation;cachedClientInformation;clientInformationLoaded=!1;cachedDiscoveryState;discoveryStateLoaded=!1;cachedTokens;tokensLoaded=!1;connectionFingerprintValue;usedRefreshTokenFingerprintValue;constructor(t){let r=Bu({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=Lu(t,this.configuredClientInformation)}get authorizationUrl(){return this.authorizationUrlValue}get usedRefreshTokenFingerprint(){return this.usedRefreshTokenFingerprintValue}async connectionFingerprint(){return this.connectionFingerprintValue===void 0&&(this.connectionFingerprintValue=await Ve({owner:this.target.owner,upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId})),this.connectionFingerprintValue}get redirectUrl(){return this.redirectUriValue}get clientMetadata(){return qu(this.clientMetadataValue,this.readEffectiveScope())}async state(){let t=await this.createPendingState();return Ci({id:t.id,...dt({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,J()?.info({event:"upstream_oauth_client_registered",upstreamServerId:this.target.upstreamServerId,clientId:"client_id"in t?t.client_id:void 0,redirectUriCount:"redirect_uris"in t?t.redirect_uris.length:void 0},"Upstream OAuth client registered for the gateway"),!Ou({clientInformation:t,clientMetadataUrl:this.clientMetadataUrl})&&(this.encryptedClientInformation=await Tu(t),await this.syncPendingState(!1)))}async discoveryState(){return this.readCachedDiscoveryState()}applyChallengeScope(t){this.challengeScope=t}async saveDiscoveryState(t){let r=Ei(Su.parse(t));this.cachedDiscoveryState=r,this.discoveryStateLoaded=!0,J()?.info({event:"upstream_oauth_discovery_resolved",upstreamServerId:this.target.upstreamServerId,authorizationServerHost:O(r.authorizationServerUrl),resourceMetadataHost:O(r.resourceMetadataUrl),resource:r.resourceMetadata?.resource,scopesSupportedCount:r.resourceMetadata?.scopes_supported?.length,hasResourceMetadata:r.resourceMetadata!==void 0},"Upstream OAuth discovery resolved authorization server and resource"),this.inferredScope=Mu(r,this.scopeDelimiter)}async tokens(){return this.loadStoredTokens()}async saveTokens(t){let r=$e.parse(t),o=this.target.owner.mode==="user"?this.target.owner.subjectId:void 0,i=this.connection,a=!r.refresh_token&&!!i?.encryptedRefreshToken,c=r.refresh_token?await me(r.refresh_token):this.connection?.encryptedRefreshToken;this.cachedTokens=r.refresh_token||!this.connection?.encryptedRefreshToken?r:$e.parse({...r,refresh_token:await ve(this.connection.encryptedRefreshToken)}),this.tokensLoaded=!0;let s={id:this.connection?.id??Vt(),ownerMode:this.target.owner.mode,subjectId:o,upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,status:"active",encryptedAccessToken:await me(r.access_token),encryptedRefreshToken:c,scopes:Au(r.scope??this.readEffectiveScope()),expiresAt:xu(r),metadata:this.readStoredOAuthPersistence(this.target.owner.mode==="shared"?this.target.initiatedBySubjectId:void 0)};this.connection=await b().upsertUpstreamConnection(s),J()?.info({event:"upstream_oauth_tokens_persisted",upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,ownerMode:this.target.owner.mode,connectionFingerprint:await this.connectionFingerprint(),connectionId:this.connection.id,hasRefreshToken:!!c,priorStatus:i?.status,priorUpdatedAt:i?.updatedAt,usedRefreshTokenFingerprint:this.usedRefreshTokenFingerprintValue,newRefreshTokenFingerprint:await We(r.refresh_token),reusedSnapshotRefreshToken:a,scopeCount:s.scopes.length,expiresAt:s.expiresAt},"Upstream OAuth tokens persisted; upstream connection is active")}async redirectToAuthorization(t){let r=Oi(t);this.authorizationUrlValue=r.toString()}async saveCodeVerifier(t){let r=await this.createPendingState();await this.persistPendingState({...r,codeVerifier:ku(t)})}async codeVerifier(){if(!this.pendingState?.codeVerifier)throw new h({message:"OAuth code verifier is missing",extensionMembers:{[g]:"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.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:zo(),...dt({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:I(new Date(Date.now()+bi)),redirectUri:this.redirectUriValue,...this.returnOrigin===void 0?{}:{returnOrigin:this.returnOrigin},encryptedClientInformation:this.encryptedClientInformation,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})}async loadPersistedClientInformation(){if(this.clientInformationLoaded)return this.cachedClientInformation;let t;try{t=await Uu(this.encryptedClientInformation,Iu)}catch{this.encryptedClientInformation=void 0,this.cachedClientInformation=void 0,this.clientInformationLoaded=!0,await this.syncPendingState(!1),await this.persistCredentialInvalidation(!1);return}if(t&&(!Pu(t,this.redirectUriValue)||!Eu({clientInformation:t,clientMetadataUrl:this.clientMetadataUrl}))){this.encryptedClientInformation=void 0,this.cachedClientInformation=void 0,this.clientInformationLoaded=!0,await this.syncPendingState(!1),await this.persistCredentialInvalidation(!1);return}return t===void 0&&this.pendingState?.codeVerifier!==void 0&&this.clientMetadataUrl!==void 0&&(t=rr.parse({client_id:this.clientMetadataUrl})),this.cachedClientInformation=t,this.clientInformationLoaded=!0,this.cachedClientInformation}async readCachedDiscoveryState(){if(this.discoveryStateLoaded)return this.cachedDiscoveryState;this.discoveryStateLoaded=!0}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"){J()?.debug({event:"upstream_oauth_tokens_not_loaded",upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,connectionFingerprint:await this.connectionFingerprint(),connectionId:this.connection?.id,status:this.connection?.status??"not_connected"},"Upstream OAuth tokens not loaded; connection is not active");return}let t=this.connection.encryptedAccessToken?await ve(this.connection.encryptedAccessToken):void 0,r=this.connection.encryptedRefreshToken?await ve(this.connection.encryptedRefreshToken):void 0;if(!t&&!r)return;let o=J();this.usedRefreshTokenFingerprintValue=o?await We(r):void 0,o?.debug({event:"upstream_oauth_tokens_loaded",upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,connectionFingerprint:await this.connectionFingerprint(),connectionId:this.connection.id,hasAccessToken:!!t,hasRefreshToken:!!r,usedRefreshTokenFingerprint:this.usedRefreshTokenFingerprintValue,expiresAt:this.connection.expiresAt},"Upstream OAuth tokens loaded from stored connection");let i=$e.parse({access_token:t??vu,token_type:Cu,refresh_token:r,scope:this.connection.scopes.length>0?this.connection.scopes.join(" "):void 0});return this.cachedTokens=i,i}async persistCredentialInvalidation(t){if(!this.connection)return;let r=this.connection.status,o=this.connection.updatedAt,i={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&&(i.status="reconsent_required",i.encryptedAccessToken=void 0,i.encryptedRefreshToken=void 0,i.scopes=[],i.expiresAt=void 0),i.metadata=this.readStoredOAuthPersistence(this.connection.metadata?.connectedBySubjectId),this.connection=await b().upsertUpstreamConnection(i);let a=J();if(a){let c={event:"upstream_oauth_credentials_invalidated",upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,connectionFingerprint:await this.connectionFingerprint(),connectionId:this.connection.id,clearedTokens:t,priorStatus:r,newStatus:this.connection.status,priorUpdatedAt:o,usedRefreshTokenFingerprint:this.usedRefreshTokenFingerprintValue};t?a.warn(c,"Upstream OAuth credentials invalidated; connection now requires reconsent"):a.debug(c,"Upstream OAuth credential metadata rewritten")}}readStoredOAuthPersistence(t){if(!(!this.encryptedClientInformation&&!t))return{encryptedClientInformation:this.encryptedClientInformation,connectedBySubjectId:t}}};var Nu=3e4,Ju=256*1024,Gu=2,Fu="does not support dynamic client registration",$u=["Resource server does not implement OAuth 2.0 Protected Resource Metadata","trying to load well-known OAuth protected resource metadata"],Zu=["HTTP 403 Forbidden","Access Denied","permission to access"],Ku=new Set(["access_denied","invalid_client","invalid_grant","invalid_request","invalid_scope","invalid_target","unauthorized_client","unsupported_grant_type"]);function Wu(e){return e instanceof Error&&e.message.includes(Fu)}n(Wu,"isDynamicClientRegistrationUnsupported");function Vu(e){return e instanceof Error&&$u.some(t=>e.message.includes(t))}n(Vu,"isProtectedResourceMetadataUnavailable");function Yu(e){return e instanceof Error&&Zu.some(t=>e.message.includes(t))}n(Yu,"isUpstreamProviderAccessDenied");function Xu(e){return e instanceof A&&Ku.has(e.errorCode)}n(Xu,"isStoredConnectionReconsentError");function Qu(e){if(e.error instanceof h&&e.error.extensionMembers?.[g]!==void 0)return e.error;if(Wu(e.error))return new h({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:{[g]:"upstream_client_registration_required"}},{cause:e.error});if(Vu(e.error))return new h({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:{[g]:"upstream_oauth_discovery_unavailable"}},{cause:e.error});if(Yu(e.error))return new h({message:`The upstream provider denied access while connecting ${e.upstreamServerId}. Confirm the provider allows this gateway and its OAuth client, then retry.`,extensionMembers:{[g]:"upstream_provider_access_denied"}},{cause:e.error})}n(Qu,"mapUpstreamOAuthSetupError");function el(e){return typeof e=="string"||e instanceof URL?{url:new URL(e.toString())}:{method:e.method,url:new URL(e.url)}}n(el,"readOAuthFetchRequest");function tl(e,t){return(e.headers.get("content-type")??"").includes("json")||t.trimStart().startsWith("{")||t.trimStart().startsWith("[")}n(tl,"responseLooksJson");function rl(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(rl,"responseLooksHtml");function nl(e){let t=e.response.statusText?` ${e.response.statusText}`:"",r=e.response.headers.get("content-type")??"text/html";throw new h({message:`The upstream provider returned ${e.response.status}${t} (${r}) from ${e.request.url.toString()} while connecting ${e.upstreamServerId}.`,extensionMembers:{[g]:e.response.status===403?"upstream_provider_access_denied":"upstream_token_exchange_failed",[_e]:e.response.status,[Le]:r,[we]:e.request.url.toString(),[Ne]:e.body}})}n(nl,"throwUpstreamHtmlError");function ol(e){try{let t=JSON.parse(e);if(typeof t!="object"||t===null)return{};let r=t;return{error:typeof r.error=="string"?r.error:void 0,errorDescription:typeof r.error_description=="string"?r.error_description:void 0}}catch{return{}}}n(ol,"readUpstreamOAuthErrorBody");function il(e){let{error:t,errorDescription:r}=ol(e.body);e.log?.warn({event:"upstream_oauth_http_error",upstreamServerId:e.upstreamServerId,method:e.request.method??"GET",host:O(e.request.url),path:e.request.url.pathname,status:e.response.status,oauthError:t,oauthErrorDescription:r?.slice(0,256)},"Upstream OAuth HTTP request returned an error response")}n(il,"logUpstreamOAuthHttpError");function Hi(e){return async(t,r)=>{let o=el(t),i=J(),a=Date.now(),c=await si(t,r,{maxRedirects:Gu,maxResponseBytes:Ju,problemCode:"upstream_token_exchange_failed",timeoutMs:Nu}),s=await c.clone().text();if(i?.debug({event:"upstream_oauth_http_request",upstreamServerId:e,method:o.method??"GET",host:O(o.url),path:o.url.pathname,status:c.status,durationMs:Date.now()-a,responseChars:s.length},"Upstream OAuth HTTP request completed"),c.ok||il({log:i,upstreamServerId:e,request:o,response:c,body:s}),!c.ok&&rl(c,s)&&nl({upstreamServerId:e,request:o,response:c,body:s}),!tl(c,s))return c;try{JSON.parse(s)}catch(u){throw new h({message:`Upstream OAuth fetch ${o.url.origin}${o.url.pathname} for ${e} returned invalid JSON.`,extensionMembers:{[g]:"upstream_token_exchange_failed"}},{cause:u})}return c}}n(Hi,"createUpstreamOAuthFetch");function Bi(e){J()?.debug({event:e.phase==="authorize"?"upstream_oauth_authorize_started":"upstream_oauth_token_exchange_started",upstreamServerId:e.upstreamServerId,serverHost:O(e.serverUrl),resourceMetadataHost:O(e.resourceMetadataUrl),hasRequestedScope:e.requestedScope!==void 0},e.phase==="authorize"?"Upstream OAuth authorization flow started":"Upstream OAuth authorization-code exchange started")}n(Bi,"logUpstreamOAuthFlowStarted");function Li(e){let t={event:"upstream_oauth_flow_failed",phase:e.phase,upstreamServerId:e.upstreamServerId},r=O(e.serverUrl);r!==void 0&&(t.serverHost=r);let o=e.error instanceof h?e.error.extensionMembers?.[g]:void 0;typeof o=="string"&&(t.code=o),N(t,"error",e.error),J()?.warn(t,"Upstream OAuth flow failed before a connection was established")}n(Li,"logUpstreamOAuthFlowFailed");async function Ni(e,t){e.applyChallengeScope(t.requestedScope),Bi({phase:"authorize",...t});try{let r={serverUrl:t.serverUrl,resourceMetadataUrl:new URL(t.resourceMetadataUrl),fetchFn:Hi(t.upstreamServerId)};return t.requestedScope!==void 0&&(r.scope=t.requestedScope),await Gr(e,r)}catch(r){Li({phase:"authorize",upstreamServerId:t.upstreamServerId,serverUrl:t.serverUrl,error:r});let o=Qu({upstreamServerId:t.upstreamServerId,resourceMetadataUrl:t.resourceMetadataUrl,error:r});throw o!==void 0?o:r}}n(Ni,"runUpstreamOAuth");async function al(e,t){e.applyChallengeScope(t.requestedScope),Bi({phase:"token_exchange",...t});let r={serverUrl:t.serverUrl,authorizationCode:t.authorizationCode,resourceMetadataUrl:new URL(t.resourceMetadataUrl),fetchFn:Hi(t.upstreamServerId)};t.requestedScope!==void 0&&(r.scope=t.requestedScope);try{return await Gr(e,r)}catch(o){throw Li({phase:"token_exchange",upstreamServerId:t.upstreamServerId,serverUrl:t.serverUrl,error:o}),o}}n(al,"exchangeUpstreamAuthorizationCode");async function Ji(e,t){let r=await Ni(e,t);if(r==="REDIRECT"&&e.authorizationUrl)return e.authorizationUrl;throw r==="AUTHORIZED"?new h({message:`OAuth connect flow reused existing credentials instead of producing a redirect for ${t.upstreamServerId}`,extensionMembers:{[g]:"upstream_token_exchange_failed"}}):new h({message:`Unexpected OAuth result for ${t.upstreamServerId}: ${r}`,extensionMembers:{[g]:"upstream_token_exchange_failed"}})}n(Ji,"requireUpstreamAuthorizationRedirect");async function Gi(e){let t=Tt(e.connection),r=!!e.forceRefresh,o=!r&&t==="usable",i=J(),a=i?await Ve({owner:e.target.owner,upstreamServerId:e.target.upstreamServerId,authProfileId:e.target.authProfileId}):void 0;if(i?.debug({event:"upstream_oauth_refresh_decision",upstreamServerId:e.target.upstreamServerId,authProfileId:e.target.authProfileId,ownerMode:e.target.owner.mode,connectionFingerprint:a,connectionId:e.connection?.id,accessTokenState:t,forceRefresh:r,willRefresh:!o,expiresAt:e.connection?.expiresAt,connectionUpdatedAt:e.connection?.updatedAt},o?"Reusing stored upstream access token":"Refreshing upstream credential"),o)return{kind:"authorized",credential:{type:"mcp_oauth_provider",provider:e.provider}};let c;try{c=await Ni(e.provider,{upstreamServerId:e.target.upstreamServerId,serverUrl:e.serverUrl,resourceMetadataUrl:e.resourceMetadataUrl,...e.requestedScope===void 0?{}:{requestedScope:e.requestedScope}})}catch(s){if(e.connection===void 0||!Xu(s))throw s;return i?.warn({event:"upstream_oauth_connection_reconsent_required",upstreamServerId:e.target.upstreamServerId,authProfileId:e.target.authProfileId,oauthError:s.errorCode,connectionFingerprint:a,connectionId:e.connection.id,rejectedRefreshTokenFingerprint:e.provider.usedRefreshTokenFingerprint,connectionUpdatedAt:e.connection.updatedAt,connectionExpiresAt:e.connection.expiresAt},"Stored upstream OAuth connection was rejected by the upstream provider"),await e.provider.invalidateCredentials("all"),{kind:"connect_required",payload:await zi({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}})}}if(c==="AUTHORIZED")return{kind:"authorized",credential:{type:"mcp_oauth_provider",provider:e.provider}};if(c!=="REDIRECT")throw new h({message:`Unexpected OAuth result for ${e.target.upstreamServerId}: ${c}`,extensionMembers:{[g]:"upstream_token_exchange_failed"}});if(!e.provider.authorizationUrl)throw new h({message:`OAuth connect-required flow did not produce a redirect for ${e.target.upstreamServerId}`,extensionMembers:{[g]:"upstream_token_exchange_failed"}});return{kind:"connect_required",payload:await zi({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(Gi,"authorizeUpstreamOAuthSession");async function sl(e){let t=await cr(e.stateToken),r=await b().consumeUpstreamOAuthState({id:t.id,now:I(new Date)}),o=cl(r);return dl({storedState:o,signedState:t,upstreamServerId:e.upstreamServerId,callbackPath:new URL(e.request.url).pathname}),ul(o),o}n(sl,"consumeStoredCallbackState");function cl(e){switch(e.kind){case"consumed":throw new h({message:"OAuth state has already been used",extensionMembers:{[g]:"oauth_state_reused"}});case"missing":throw new h({message:"OAuth state is missing or expired",extensionMembers:{[g]:"oauth_state_expired"}});case"available":return e.record}}n(cl,"readConsumedCallbackState");function dl(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 h({message:"OAuth callback did not match the initiating request",extensionMembers:{[g]:"oauth_callback_mismatch"}})}n(dl,"assertStoredCallbackStateMatches");function ul(e){if(new Date(e.expiresAt).getTime()<=Date.now())throw new h({message:"OAuth state has expired",extensionMembers:{[g]:"oauth_state_expired"}})}n(ul,"assertStoredCallbackStateFresh");async function zi(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),xi(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),dr(t)}n(zi,"buildOAuthConnectRequiredResponse");async function Fi(e){let t=await sl({request:e.request,upstreamServerId:e.upstreamServerId,stateToken:e.stateToken}),r=Ft(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 qe(i),c=await al(a,{upstreamServerId:e.upstreamServerId,serverUrl:e.upstreamServerConfig.transport.baseUrl,authorizationCode:e.authorizationCode,resourceMetadataUrl:e.upstreamServerConfig.transport.resourceMetadataUrl});if(c==="AUTHORIZED")return t;throw c!=="REDIRECT"?new h({message:`Unexpected OAuth result for ${e.upstreamServerId}: ${c}`,extensionMembers:{[g]:"upstream_token_exchange_failed"}}):new h({message:`OAuth callback flow did not finish authorization for ${e.upstreamServerId}`,extensionMembers:{[g]:"upstream_token_exchange_failed"}})}n(Fi,"finishUpstreamOAuthCallback");K();import{importPKCS8 as ll,SignJWT as pl}from"jose";var Zi=1e4,Ki=64*1024,Wi=2,ml=300,oe=d.string().min(1),fl=d.object({access_token:oe,issued_token_type:d.literal(kr),token_type:d.string().optional(),expires_in:d.number().int().positive().optional(),scope:oe.optional()}).passthrough(),hl=d.object({id_token:oe,token_type:oe.optional(),expires_in:d.number().int().positive().optional(),refresh_token:oe.optional(),scope:oe.optional()}).passthrough(),gl=d.object({access_token:oe,token_type:oe,expires_in:d.number().int().positive().optional(),scope:oe.optional(),resource:oe.optional(),refresh_token:oe.optional()}).passthrough();function $i(e){return encodeURIComponent(e).replace(/%20/g,"+")}n($i,"formEncodeClientCredential");function yl(e){return e.replaceAll("\\n",`
26
- `)}n(yl,"normalizePem");async function _l(e){let t=e.clientAuth.algorithm??"RS256",r=e.clientAuth.expiresInSeconds??ml,o=await ll(yl(e.clientAuth.privateKeyPem),t),i={alg:t,typ:"JWT",...e.clientAuth.keyId===void 0?{}:{kid:e.clientAuth.keyId}};return new pl({jti:crypto.randomUUID()}).setProtectedHeader(i).setIssuer(e.clientAuth.clientId).setSubject(e.clientAuth.clientId).setAudience(e.clientAuth.audience??e.tokenUrl).setIssuedAt().setExpirationTime(`${r}s`).sign(o)}n(_l,"createPrivateKeyJwtClientAssertion");async function wl(e){switch(e.clientAuth.method){case"client_secret_post":e.form.set("client_id",e.clientAuth.clientId),e.form.set("client_secret",e.clientAuth.clientSecret);return;case"client_secret_basic":{let t=$i(e.clientAuth.clientId),r=$i(e.clientAuth.clientSecret);e.headers.authorization=`Basic ${btoa(`${t}:${r}`)}`;return}case"private_key_jwt":e.form.set("client_id",e.clientAuth.clientId),e.form.set("client_assertion_type",Zt),e.form.set("client_assertion",await _l({clientAuth:e.clientAuth,tokenUrl:e.tokenUrl}));return}}n(wl,"appendClientAuthentication");async function on(e){let t={"Content-Type":"application/x-www-form-urlencoded"};return await wl({form:e.form,headers:t,clientAuth:e.clientAuth,tokenUrl:e.tokenUrl}),{method:"POST",headers:t,body:e.form.toString()}}n(on,"buildFormRequest");function Vi(e){return(t,r)=>sr(t,r,{context:e,maxRedirects:Wi,maxResponseBytes:Ki,problemCode:"upstream_token_exchange_failed",timeoutMs:Zi})}n(Vi,"defaultIdpFetchJson");function Rl(e){return(t,r)=>ci(t,r,{context:e,maxRedirects:Wi,maxResponseBytes:Ki,problemCode:"upstream_token_exchange_failed",timeoutMs:Zi})}n(Rl,"defaultResourceAsFetchJson");function lr(e){let t={[g]:e.code,[we]:e.tokenUrl};return e.response!==void 0&&(t[_e]=e.response.status),new h({message:e.message,extensionMembers:t},e.cause===void 0?void 0:{cause:e.cause})}n(lr,"runtimeError");function an(e){if(!e.response.ok)throw lr({code:"upstream_token_exchange_failed",message:(()=>{switch(e.stage){case"idp_refresh_token":return"IdP refresh-token grant failed while renewing the upstream ID-JAG subject token.";case"idp_token_exchange":return"IdP token exchange failed while requesting an upstream ID-JAG.";case"resource_as_jwt_bearer":return"Upstream Resource AS rejected the ID-JAG JWT-bearer exchange."}})(),tokenUrl:e.tokenUrl,response:e.response})}n(an,"assertTokenEndpointSucceeded");function bl(e){let t=hl.safeParse(e.json);if(!t.success)throw lr({code:"upstream_token_response_invalid",message:"IdP refresh-token grant returned an invalid subject-token response.",tokenUrl:e.tokenUrl,response:e.response,cause:t.error});let r={idToken:t.data.id_token};return t.data.expires_in!==void 0&&(r.expiresIn=t.data.expires_in),t.data.refresh_token!==void 0&&(r.refreshToken=t.data.refresh_token),t.data.scope!==void 0&&(r.scope=t.data.scope),r}n(bl,"parseIdpRefreshTokenResponse");function Il(e){let t=fl.safeParse(e.json);if(!t.success)throw lr({code:"upstream_token_response_invalid",message:"IdP token exchange returned an invalid ID-JAG response.",tokenUrl:e.tokenUrl,response:e.response,cause:t.error});let r={assertion:t.data.access_token};return t.data.expires_in!==void 0&&(r.expiresIn=t.data.expires_in),t.data.scope!==void 0&&(r.scope=t.data.scope),r}n(Il,"parseIdJagTokenExchangeResponse");function Sl(e){let t=gl.safeParse(e.json);if(!t.success)throw lr({code:"upstream_token_response_invalid",message:"Upstream Resource AS returned an invalid JWT-bearer token response.",tokenUrl:e.tokenUrl,response:e.response,cause:t.error});let r={accessToken:t.data.access_token,tokenType:t.data.token_type};return t.data.expires_in!==void 0&&(r.expiresIn=t.data.expires_in),t.data.scope!==void 0&&(r.scope=t.data.scope),t.data.resource!==void 0&&(r.resource=t.data.resource),t.data.refresh_token!==void 0&&(r.refreshToken=t.data.refresh_token),r}n(Sl,"parseAccessTokenResponse");async function Yi(e){let t=new URLSearchParams({grant_type:$t,requested_token_type:kr,subject_token:e.subjectToken,subject_token_type:e.subjectTokenType,audience:e.audience});e.resource!==void 0&&t.set("resource",e.resource),e.scope!==void 0&&t.set("scope",e.scope),e.authorizationDetails!==void 0&&t.set("authorization_details",JSON.stringify(e.authorizationDetails));let r=e.fetchJson??Vi(e.context),{response:o,json:i}=await r(e.idp.tokenUrl,await on({form:t,clientAuth:e.clientAuth,tokenUrl:e.idp.tokenUrl}));return an({response:o,tokenUrl:e.idp.tokenUrl,stage:"idp_token_exchange"}),Il({json:i,response:o,tokenUrl:e.idp.tokenUrl})}n(Yi,"requestIdJag");async function Xi(e){let t=new URLSearchParams({grant_type:"refresh_token",refresh_token:e.refreshToken}),r=e.fetchJson??Vi(e.context),{response:o,json:i}=await r(e.idp.tokenUrl,await on({form:t,clientAuth:e.clientAuth,tokenUrl:e.idp.tokenUrl}));return an({response:o,tokenUrl:e.idp.tokenUrl,stage:"idp_refresh_token"}),bl({json:i,response:o,tokenUrl:e.idp.tokenUrl})}n(Xi,"refreshIdpSubjectToken");async function Qi(e){let t=new URLSearchParams({grant_type:be,assertion:e.assertion});e.resource!==void 0&&t.set("resource",e.resource),e.scope!==void 0&&t.set("scope",e.scope);let r=e.fetchJson??Rl(e.context),{response:o,json:i}=await r(e.resourceAs.tokenUrl,await on({form:t,clientAuth:e.clientAuth,tokenUrl:e.resourceAs.tokenUrl}));return an({response:o,tokenUrl:e.resourceAs.tokenUrl,stage:"resource_as_jwt_bearer"}),Sl({json:i,response:o,tokenUrl:e.resourceAs.tokenUrl})}n(Qi,"exchangeIdJagForAccessToken");function Cl(e){return Tt(e)==="usable"}n(Cl,"hasUsableAccessToken");function vl(e){if(e.tokenType.toLowerCase()!=="bearer")throw new h({message:"Upstream Resource AS returned a token type the MCP gateway cannot send as a bearer token.",extensionMembers:{[g]:"upstream_token_response_invalid"}})}n(vl,"assertBearerToken");function ea(e,t){if(t===Fe)return!1;let r=e?.metadata?.idpSubjectTokenExpiresAt;return r!==void 0&&new Date(r).getTime()<=Date.now()}n(ea,"hasExpiredSubjectToken");async function Al(e){let t=await ve(e.encryptedSubjectToken);if(e.subjectTokenType!==Fe)return{connection:e.connection,subjectToken:t,subjectTokenType:e.subjectTokenType};let r=await Xi({idp:e.idp,refreshToken:t,clientAuth:e.clientAuth,context:e.context});if(r.refreshToken===void 0)return{connection:e.connection,subjectToken:r.idToken,subjectTokenType:ut};let o=await b().upsertUpstreamConnection({id:e.connection.id,ownerMode:e.connection.ownerMode,subjectId:e.connection.subjectId,upstreamServerId:e.connection.upstreamServerId,authProfileId:e.connection.authProfileId,status:"active",encryptedAccessToken:e.connection.encryptedAccessToken,encryptedRefreshToken:e.connection.encryptedRefreshToken,scopes:e.connection.scopes,expiresAt:e.connection.expiresAt,metadata:{...e.connection.metadata??{},encryptedIdpSubjectToken:await me(r.refreshToken),idpSubjectTokenType:Fe,idpSubjectTokenExpiresAt:void 0}});return J()?.info({event:"upstream_id_jag_subject_token_rotated",upstreamServerId:e.connection.upstreamServerId,authProfileId:e.connection.authProfileId,connectionFingerprint:e.connectionFingerprint,connectionId:o.id,priorStatus:e.connection.status,priorUpdatedAt:e.connection.updatedAt,usedSubjectRefreshTokenFingerprint:await We(t),newSubjectRefreshTokenFingerprint:await We(r.refreshToken)},"Upstream ID-JAG IdP subject refresh token rotated and persisted"),{connection:o,subjectToken:r.idToken,subjectTokenType:ut}}n(Al,"resolveIdJagSubjectToken");async function ta(e){let t="preloadedConnection"in e?e.preloadedConnection:(await b().batchGetUpstreamConnections([{owner:e.owner,upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId}]))[0],r=Tt(t),o=!!e.forceRefresh,i=!o&&r==="usable",a=J(),c=a?await Ve({owner:e.owner,upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId}):void 0;if(a?.debug({event:"upstream_id_jag_auth_decision",upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,ownerMode:e.owner.mode,connectionFingerprint:c,connectionId:t?.id,accessTokenState:r,forceRefresh:o,willMint:!i,expiresAt:t?.expiresAt,connectionUpdatedAt:t?.updatedAt},i?"Reusing stored upstream ID-JAG access token":"Minting upstream ID-JAG access token"),!e.forceRefresh&&Cl(t))return{kind:"authorized",credential:{type:"bearer_token",token:await ve(t.encryptedAccessToken)}};let s=t?.metadata?.encryptedIdpSubjectToken,u=t?.metadata?.idpSubjectTokenType;if(t?.status!=="active"||s===void 0||u===void 0||ea(t,u))return a?.debug({event:"upstream_id_jag_connect_required",upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,connectionFingerprint:c,connectionId:t?.id,status:t?.status??"not_connected",hasSubjectToken:s!==void 0,subjectTokenType:u,subjectTokenExpired:u!==void 0&&ea(t,u)},"Upstream ID-JAG requires an admin subject-token binding"),{kind:"connect_required",payload:{state:"admin_connect_required",upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,operationId:e.operationId,message:`An IdP subject-token binding is required for ${e.upstreamDisplayName} before this tool can use XAA / ID-JAG.`,nextAction:"admin_setup_required"}};let p=Ie(e.upstreamServerId),f=oi(e.upstreamServerId,e.authProfileId),w=f.resourceAs.resource??p.transport.baseUrl,U=e.requestedScope??(f.scopes.length===0?void 0:f.scopes.join(f.scopeDelimiter)),y=await Al({connection:t,connectionFingerprint:c,encryptedSubjectToken:s,subjectTokenType:u,idp:{tokenUrl:f.idp.tokenUrl},clientAuth:f.idp.clientAuth,context:e.context}),P=await Yi({idp:{tokenUrl:f.idp.tokenUrl},subjectToken:y.subjectToken,subjectTokenType:y.subjectTokenType,audience:f.resourceAs.audience,resource:w,scope:U,clientAuth:f.idp.clientAuth,context:e.context}),k=P.scope??U,z=await Qi({resourceAs:{tokenUrl:f.resourceAs.tokenUrl},assertion:P.assertion,resource:w,scope:k,clientAuth:f.resourceAs.clientAuth,context:e.context});if(vl(z),t!==void 0){let Q=(z.scope??k)?.split(/[,\s]+/).filter(Boolean)??[],E=z.expiresIn===void 0?void 0:I(new Date(Date.now()+z.expiresIn*1e3)),D=await b().upsertUpstreamConnection({id:y.connection.id,ownerMode:y.connection.ownerMode,subjectId:y.connection.subjectId,upstreamServerId:y.connection.upstreamServerId,authProfileId:y.connection.authProfileId,status:"active",encryptedAccessToken:await me(z.accessToken),encryptedRefreshToken:y.connection.encryptedRefreshToken,scopes:Q,expiresAt:E,metadata:y.connection.metadata});a?.info({event:"upstream_id_jag_access_token_persisted",upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,connectionFingerprint:c,connectionId:D.id,priorStatus:y.connection.status,priorUpdatedAt:y.connection.updatedAt,scopeCount:Q.length,expiresAt:E},"Upstream ID-JAG access token persisted; connection is active")}return{kind:"authorized",credential:{type:"bearer_token",token:z.accessToken}}}n(ta,"authorizeUpstreamIdJagRequest");function kl(e){return ur(new URL(e.callbackPath,q(e.requestUrl,e.requestHeaders))).toString()}n(kl,"buildGatewayOAuthRedirectUri");async function ra(e){let t=Ie(e.upstreamServerId),r=Ze(e.upstreamServerId,e.authProfileId),o=kl({callbackPath:r.redirectPath,requestUrl:e.request.url,requestHeaders: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,returnTo:e.returnTo},redirectUri:o,returnOrigin:q(e.request.url,e.request.headers)}}}n(ra,"prepareUpstreamOAuthRequest");async function na(e){let t=await ra(e),r=new qe({...t.providerInput,...t.connection?.metadata===void 0?{}:{connectionMetadata:t.connection.metadata}});return Ji(r,{upstreamServerId:e.upstreamServerId,serverUrl:t.upstreamServerConfig.transport.baseUrl,resourceMetadataUrl:t.upstreamServerConfig.transport.resourceMetadataUrl})}n(na,"startUpstreamConnect");async function oa(e){let t=await ra(e),r=new qe({...t.providerInput,...t.connection===void 0?{}:{connection:t.connection}});return Gi({target:e,provider:r,connection:t.connection,forceRefresh:e.forceRefresh,requestedScope:e.requestedScope,upstreamDisplayName:t.upstreamServerConfig.displayName,serverUrl:t.upstreamServerConfig.transport.baseUrl,resourceMetadataUrl:t.upstreamServerConfig.transport.resourceMetadataUrl})}n(oa,"authorizeUpstreamRequest");async function Xe(e){let{routeAuth:t}=e;switch(t.authMode){case"shared-oauth":case"user-oauth":return oa({request:e.request,owner:t.owner,initiatedBySubjectId:t.initiatedBySubjectId,upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId,operationId:t.operationId,forceRefresh:e.forceRefresh,requestedScope:e.requestedScope,...e.preloadedConnection===void 0?{}:{preloadedConnection:e.preloadedConnection},returnTo:t.returnTo});case"id-jag":return ta({request:e.request,context:e.context,authMode:t.authMode,ownerMode:t.ownerMode,owner:t.owner,initiatedBySubjectId:t.initiatedBySubjectId,upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId,operationId:t.operationId,upstreamDisplayName:t.upstreamDisplayName,forceRefresh:e.forceRefresh,requestedScope:e.requestedScope,...e.preloadedConnection===void 0?{}:{preloadedConnection:e.preloadedConnection},returnTo:t.returnTo})}let r=t;throw new ee(`Unsupported upstream auth route context ${JSON.stringify(r)}.`)}n(Xe,"resolveUpstreamCredentialForRoute");async function ia(e){if(e.connectRequest.authMode==="id-jag")throw new ee(`Upstream server ${e.connectRequest.upstreamServerId} uses XAA / ID-JAG and does not support browser OAuth connection flows.`);let t=await na({request:e.request,owner:e.connectRequest.owner,initiatedBySubjectId:e.connectRequest.initiatedBySubjectId,upstreamServerId:e.connectRequest.upstreamServerId,authProfileId:e.connectRequest.authProfileId,operationId:e.connectRequest.operationId,returnTo:e.connectRequest.returnTo});return{authProfileId:e.connectRequest.authProfileId,authUrl:t,initiatedBySubjectId:e.connectRequest.initiatedBySubjectId,owner:e.connectRequest.owner,upstreamDisplayName:e.connectRequest.upstreamDisplayName,operationId:e.connectRequest.operationId}}n(ia,"startUpstreamConnectForRequest");async function aa(e){let r=(await cr(e.callbackRequest.state)).authProfileId;if(ir({upstreamServerId:e.callbackRequest.upstreamServerId,authProfileId:r}).mode==="id-jag")throw new ee(`Upstream server ${e.callbackRequest.upstreamServerId} uses XAA / ID-JAG and does not support OAuth callbacks.`);return Fi({request:e.request,upstreamServerId:e.callbackRequest.upstreamServerId,authorizationCode:e.callbackRequest.code,stateToken:e.callbackRequest.state,upstreamServerConfig:Ie(e.callbackRequest.upstreamServerId)})}n(aa,"finishUpstreamCallbackForRequest");function xl(e){return{upstreamServerId:e.connection.upstreamServerId,operationId:e.operationId,authProfileId:e.connection.authProfileId,upstreamDisplayName:e.connection.displayName,authMode:e.connection.authMode,ownerMode:e.connection.ownerMode}}n(xl,"buildRouteAuthBaseFromConnection");function sa(e){return{upstreamServerId:e.connection.id,operationId:e.operationId,authProfileId:mo(e.connection.id,e.connection.authMode),upstreamDisplayName:e.connection.displayName,authMode:e.connection.authMode,ownerMode:e.connection.ownerMode}}n(sa,"buildRouteAuthBaseFromPolicyOptions");function pr(e,t){let o=te().byOperationId.get(t);if(!o)throw new B(`Unknown MCP route "${t}". Ensure routes.oas.json declares this operationId before starting an upstream connection flow.`);if(o.connection===void 0)throw new B(`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 B(`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 xl({connection:o.connection,operationId:t})}n(pr,"resolveRouteAuthBase");function sn(e,t){switch(e){case"user":return Je(t);case"shared":return lo()}}n(sn,"buildOwnerForSubject");function Qe(e,t){switch(e.authMode){case"shared-oauth":return{...e,authMode:"shared-oauth",ownerMode:"shared",owner:sn("shared",t),initiatedBySubjectId:t};case"user-oauth":return{...e,authMode:"user-oauth",ownerMode:"user",owner:sn("user",t),initiatedBySubjectId:t};case"id-jag":return{...e,authMode:"id-jag",ownerMode:"user",owner:sn("user",t),initiatedBySubjectId:t}}}n(Qe,"resolveRouteAuthForSubject");var Tl=st.InvalidRequest,Ul=new Set(["connection","keep-alive","proxy-authenticate","te","trailer","transfer-encoding","upgrade"]);function Pl(e,t){return{credentialType:e.type,forceRefresh:t}}n(Pl,"buildCredentialResolvedAttributes");function El(e){switch(e){case"admin_connect_required":return"admin_connect_required";case"authenticating":return"connect_required"}}n(El,"connectRequiredReasonCode");function ca(e){v(e.context,{eventType:S.MCP_AUTH_UPSTREAM_CREDENTIAL_RESOLVED,outcome:"success",routeBinding:e.routeBinding,attributes:Pl(e.credential,e.forceRefresh===!0)})}n(ca,"emitCredentialResolvedAnalyticsEvent");function da(e){let t={forceRefresh:e.forceRefresh===!0,nextAction:e.payload.nextAction,state:e.payload.state};if(v(e.context,{eventType:S.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:S.MCP_AUTH_UPSTREAM_RECONSENT_REQUIRED,outcome:"connect_required",routeBinding:e.routeBinding,reasonCode:"reconsent_required",reasonClass:"auth",attributes:t});return}v(e.context,{eventType:S.MCP_AUTH_UPSTREAM_CONNECT_REQUIRED,outcome:"connect_required",routeBinding:e.routeBinding,reasonCode:El(e.payload.state),reasonClass:"auth",attributes:t})}n(da,"emitCredentialMissingAnalyticsEvents");function Ol(e){let t=e.route.raw();return Nt.parse(t?.operationId)}n(Ol,"readOperationId");async function ql(e,t,r,o){let i=await Xe({request:e,context:o,routeAuth:t});if(i.kind==="connect_required")return da({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;if(ca({context:o,credential:a,routeBinding:t}),a.type==="bearer_token")return{kind:"headers",headers:[["authorization",`Bearer ${a.token}`]]};let c=await a.provider.tokens();return c?{kind:"headers",headers:[["authorization",`${c.token_type??"Bearer"} ${c.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(ql,"buildCredentialHeaders");var Ml=new Set(["authorization","cookie","cookie2"]);function Dl(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(Dl,"readJsonRequestMethod");function jl(e){let t=e.headers.get("content-type")??"";return/\bapplication\/(?:[\w.+-]+\+)?json\b/i.test(t)}n(jl,"isJsonResponse");function cn(e){return e!==null&&typeof e=="object"&&!Array.isArray(e)}n(cn,"isRecord");function zl(e){return Array.isArray(e)&&e.length>0}n(zl,"hasIconList");function Hl(e){if(e.connection.serverInfo?.icons!==void 0&&e.connection.serverInfo.icons.length>0)return e.connection.serverInfo.icons;try{let t=or(no(e.context.route.handler));return t===void 0?void 0:[t]}catch{return}}n(Hl,"readFallbackServerIcons");function Bl(e){if(!cn(e.body))return e.body;let t=e.body.result;if(!cn(t))return e.body;let r=t.serverInfo;return!cn(r)||zl(r.icons)?e.body:{...e.body,result:{...t,serverInfo:{...r,icons:e.icons}}}}n(Bl,"addMissingServerIcons");function Ll(e,t){let r=new Headers(e.headers);for(let o of Ml)r.delete(o);for(let[o,i]of t)r.set(o,i);return new Ln(e,{headers:r})}n(Ll,"applyUpstreamHeaders");function Nl(e){let t=new Headers(e.headers);for(let r of Ul)t.delete(r);return t}n(Nl,"buildProxyHeaders");async function Jl(e){if(!(e.method==="GET"||e.method==="HEAD"))return e.clone().arrayBuffer()}n(Jl,"readRetryBody");function ua(e,t){let r=t.authUrl===void 0?void 0:Lo({message:t.message,elicitationId:["connect",t.operationId,t.upstreamServerId,t.authProfileId].join(":"),url:t.authUrl});return Response.json(Xt({id:Bo(e),error:{code:r?.code??Tl,message:t.message,data:{...r?.data??{},connectRequired:t}}}))}n(ua,"connectRequiredJsonRpcResponse");async function Gl(e){let{scope:t}=Qo(e.upstreamResponse),r=await Xe({request:e.request,context:e.context,routeAuth:e.routeAuth,forceRefresh:!0,requestedScope:t});if(r.kind==="connect_required")return da({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;if(ca({context:e.context,credential:i,routeBinding:e.routeAuth,forceRefresh:!0}),i.type==="bearer_token")return o.set("authorization",`Bearer ${i.token}`),{kind:"headers",headers:o};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(Gl,"applyRefreshedCredentialHeaders");function Fl(e){e.context.addResponseSendingHook(async(t,r)=>{if(t.status!==401)return t;let o=await Gl({request:e.request,context:e.context,headers:Nl(r),routeAuth:e.routeAuth,upstreamResponse:t});if(o.kind==="connect_required")return ua(e.requestBody,o.payload);if(o.kind==="response")return o.response;let i=oo({handler:e.context.route.handler,request:r,body:e.requestBody,headers:o.headers});return jt.fetch(i.url,i.init)})}n(Fl,"installUpstreamAuthRetryHook");function $l(e){if(Dl(e.requestBody)!=="initialize")return;let t=Hl({connection:e.connection,context:e.context});t===void 0||t.length===0||e.context.addResponseSendingHook(async r=>{if(!jl(r))return r;let o;try{o=await r.clone().json()}catch{return r}let i=Bl({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($l,"installInitializeIconHook");async function dn(e,t,r){let o=Ol(t),i=await Jl(e),a=sa({connection:r,operationId:o}),c=Te(e.user,e.url,e.headers);t.log.setLogProperties?.({requestId:t.requestId}),wo(t,c);let s=Qe(a,c.subjectId),u=await ql(e,s,r,t);if(!(u instanceof Response)&&u.kind==="connect_required")return ua(i,u.payload);if(u instanceof Response)return u;let p=Ll(e,u.headers);return Fl({request:p,context:t,requestBody:i,routeAuth:s}),$l({context:t,requestBody:i,connection:r}),p}n(dn,"mcpTokenExchangePolicy");var un=class extends zt{static{n(this,"McpTokenExchangeInboundPolicy")}constructor(t,r){let o=fo(t,r);super(o,r)}async handler(t,r){return Z("policy.inbound.mcp-token-exchange"),dn(t,r,this.options)}};K();var la=Symbol("Html");function Zl(e){return e.replaceAll("&","&amp;").replaceAll("<","&lt;").replaceAll(">","&gt;").replaceAll('"',"&quot;").replaceAll("'","&#39;")}n(Zl,"escapeHtml");function Kl(e){return e===null||typeof e!="object"?!1:e[la]===!0}n(Kl,"isHtml");function pa(e){return e==null||e===!1?"":Array.isArray(e)?e.map(pa).join(""):Kl(e)?e.value:Zl(String(e))}n(pa,"renderValue");function fe(e){return{[la]:!0,value:e}}n(fe,"trustedHtml");var re=fe("");function C(e,...t){let r=e[0]??"";for(let o=0;o<t.length;o+=1)r+=pa(t[o]),r+=e[o+1]??"";return fe(r)}n(C,"html");function et(e){return e.value}n(et,"renderHtml");function ma(e){return C`<p class="card__description">${e.detail}</p>${e.guidance} ${e.technicalDetails} ${e.action}`}n(ma,"renderBrowserErrorPage");var tt=fe('*,: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 rt(e){return C`<!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 d,$b as Cc,$c as So,Ab as Yn,Ac as ee,Ad as G,Bb as Xn,Bc as H,Bd as le,Cb as q,Cc as yo,Cd as k,Db as Qn,Dc as _o,Dd as Yt,Eb as He,Ec as I,Ed as kc,Fb as eo,Fc as de,Fd as Tc,Gb as Be,Gc as Ge,Hb as g,Hc as N,Ib as Le,Ic as O,Jb as Ne,Jc as wo,Kb as _e,Kc as J,Lb as we,Lc as Ro,Mb as Bt,Mc as be,Nb as to,Nc as Ar,Ob as re,Oc as $t,P as Jn,Pb as ro,Pc as xr,Q as l,Qb as ce,Qc as Zt,R as Gn,Rb as R,Rc as ut,S as Sr,Sb as Lt,Sc as Fe,T as se,Tb as L,Tc as bo,U as Fn,Ub as Re,Uc as ue,V as _,Vb as _c,Vc as kr,W as ye,Wb as wc,Wc as Tr,X as Ht,Xb as Rc,Xc as Io,Y as $n,Yb as bc,Yc as Kt,Z as Zn,Zb as Ic,Zc as Ur,_ as Kn,_b as Sc,_c as Pr,aa as Z,ac as vc,ad as M,bc as Ac,bd as Co,cc as xc,cd as vo,dc as no,dd as Er,ec as oo,ed as Ao,fc as io,fd as xo,ga as Wn,gc as Nt,gd as Or,hc as Cr,hd as ko,i as ae,ic as Jt,id as Te,jc as Gt,jd as To,kc as st,kd as lt,lc as ao,ld as Uo,mc as so,md as Wt,nc as co,nd as pt,oc as ct,od as Po,pc as uo,pd as Eo,qc as Je,qd as Oo,r as ke,rc as lo,rd as qo,s as Bn,sc as vr,sd as Mo,tc as po,td as Do,u as Ln,uc as dt,ud as jo,vc as Ft,vd as Vt,wc as mo,wd as zo,xc as fo,xd as Ho,y as Nn,yb as Vn,yc as ho,yd as b,z as zt,zb as K,zc as go,zd as v}from"../chunk-5CYWMN74.js";import"../chunk-4MNJC7E2.js";import{a as S}from"../chunk-4QJJMELB.js";import{$ as Q,a as n,aa as h,ba as B,ca as Hn,da as jt}from"../chunk-DSZS6PZJ.js";Z();function Uc(e){let t=Gt.safeParse(e);return t.success?t.data.id:void 0}n(Uc,"parseJsonRpcRequestId");function Bo(e){if(e!==void 0)try{let t=JSON.parse(new TextDecoder().decode(e));return Uc(t)}catch{return}}n(Bo,"readJsonRpcRequestIdFromBody");function Xt(e){return ao.parse({jsonrpc:Jt,...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(Xt,"jsonRpcErrorResponse");function Lo(e){return new co([so.parse({mode:"url",message:e.message,elicitationId:e.elicitationId,url:e.url})],e.message)}n(Lo,"urlElicitationRequiredError");var Qt=d.record(d.string(),d.unknown()),Pc=d.record(d.string(),d.unknown()),Ec=d.object({name:d.string().min(1),description:d.string().min(1).optional(),annotations:Pc.optional(),_meta:Qt.optional()}).strict(),Oc=d.object({name:d.string().min(1),description:d.string().min(1).optional(),_meta:Qt.optional()}).strict(),qc=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:Qt.optional()}).strict(),Mc=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:Qt.optional()}).strict(),Dc=d.array(d.union([d.string(),Ec])),jc=d.array(d.union([d.string(),Oc])),zc=d.array(d.union([d.string(),qc])),Hc=d.array(d.union([d.string(),Mc])),Bc=d.object({tools:Dc.optional(),prompts:jc.optional(),resources:zc.optional(),resourceTemplates:Hc.optional()}).strict(),Mr=[{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 Lc(e,t){return Yn(Bc,e,`MCP capability filter policy "${t}"`)}n(Lc,"parseMcpCapabilityFilterOptions");function F(e){return e!==null&&typeof e=="object"&&!Array.isArray(e)}n(F,"isRecord");function Nc(e,t){if(!F(e))return;let r=e[t];return typeof r=="string"?r:void 0}n(Nc,"readParamString");function Dr(e){let t=e.id;return typeof t=="string"||typeof t=="number"||t===null?t:void 0}n(Dr,"readRequestId");function Fo(e){return e===void 0?void 0:JSON.stringify(e)}n(Fo,"requestIdKey");function Jc(e){let t={};for(let r of Mr){let o=e[r.option];if(o===void 0)continue;let i=new Map;for(let a of o){let c=Zc(a,r.itemProperty);c!==void 0&&i.set(c.key,c)}t[r.option]=i}return t}n(Jc,"buildProjectionMaps");function jr(e){return Mr.find(t=>t.listMethod===e)}n(jr,"findListRule");function Gc(e){return e.requests.some(t=>{if(!F(t))return!1;let r=jr(t.method);return r!==void 0&&e.projectionMaps[r.option]!==void 0})}n(Gc,"shouldFilterListResponses");function Fc(e){for(let t of Mr){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=Nc(e.request.params,o.paramProperty);if(i!==void 0&&!r.has(i))return{id:Dr(e.request)}}}}n(Fc,"findDisallowedDirectAccess");function $c(e){return Response.json(Xt({id:e,error:{code:st.MethodNotFound,message:"Method not found"}}))}n($c,"methodNotFoundResponse");function Zc(e,t){if(typeof e=="string")return{key:e,overlay:{}};if(!F(e))return;let r=e[t];if(typeof r=="string")return{key:r,overlay:e}}n(Zc,"buildProjection");function No(e){let t=e.base[e.property],r=e.overlay[e.property];return F(r)?F(t)?{...t,...r}:r:t}n(No,"mergeRecordProperty");function Kc(e,t){let r={...e,...t.overlay},o=No({base:e,overlay:t.overlay,property:"annotations"});o!==void 0&&(r.annotations=o);let i=No({base:e,overlay:t.overlay,property:"_meta"});return i!==void 0&&(r._meta=i),r}n(Kc,"applyProjection");function Jo(e,t,r){if(!F(e))return e;let o=e.result;if(!F(o))return e;let i=o[t.resultProperty];return!Array.isArray(i)||!i.every(a=>F(a)&&typeof a[t.itemProperty]=="string")?e:{...e,result:{...o,[t.resultProperty]:i.flatMap(a=>{if(!F(a))return[];let c=a[t.itemProperty];if(typeof c!="string")return[];let s=r.get(c);return s===void 0?[]:[Kc(a,s)]})}}}n(Jo,"filterAndProjectItems");function Wc(e){let t=new Map;if(!Array.isArray(e))return t;for(let r of e){if(!F(r))continue;let o=jr(r.method),i=Dr(r),a=Fo(i);o!==void 0&&a!==void 0&&t.set(a,o)}return t}n(Wc,"buildListRulesByResponseId");function Vc(e){if(Array.isArray(e.responseBody)){let o=Wc(e.requestBody);return o.size===0?e.responseBody:e.responseBody.map(i=>{if(!F(i)||"error"in i)return i;let a=Fo(Dr(i)),c=a===void 0?void 0:o.get(a),s=c===void 0?void 0:e.projectionMaps[c.option];return c===void 0||s===void 0?i:Jo(i,c,s)})}if(!F(e.requestBody)||!F(e.responseBody)||"error"in e.responseBody)return e.responseBody;let t=jr(e.requestBody.method),r=t===void 0?void 0:e.projectionMaps[t.option];return t===void 0||r===void 0?e.responseBody:Jo(e.responseBody,t,r)}n(Vc,"filterJsonRpcResponse");async function Go(e){return e.clone().json()}n(Go,"readJson");function Yc(e){return e.headers.get("content-type")?.includes("json")??!1}n(Yc,"isJsonResponse");var qr=class extends zt{static{n(this,"McpCapabilityFilterInboundPolicy")}static policyType="mcp-capability-filter";#e;constructor(t,r){let o=Lc(t,r);super(o,r),this.#e=Jc(o)}async handler(t,r){let o;try{o=await Go(t)}catch{return t}let i=Array.isArray(o)?o:[o];for(let a of i){if(!F(a))continue;let c=Fc({request:a,projectionMaps:this.#e});if(c!==void 0)return $c(c.id)}return Gc({requests:i,projectionMaps:this.#e})&&r.addResponseSendingHook(async a=>{if(!Yc(a))return a;let c;try{c=await Go(a)}catch{return a}let s=Vc({requestBody:o,responseBody:c,projectionMaps:this.#e});if(s===c)return a;let u=new Headers(a.headers);return u.delete("content-length"),new Response(JSON.stringify(s),{status:a.status,statusText:a.statusText,headers:u})}),t}};var zr;zr=globalThis.crypto;async function Xc(e){return(await zr).getRandomValues(new Uint8Array(e))}n(Xc,"getRandomValues");async function Qc(e){let t="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-._~",r=Math.pow(2,8)-Math.pow(2,8)%t.length,o="";for(;o.length<e;){let i=await Xc(e-o.length);for(let a of i)a<r&&(o+=t[a%t.length])}return o}n(Qc,"random");async function ed(e){return await Qc(e)}n(ed,"generateVerifier");async function td(e){let t=await(await zr).subtle.digest("SHA-256",new TextEncoder().encode(e));return btoa(String.fromCharCode(...new Uint8Array(t))).replace(/\//g,"_").replace(/\+/g,"-").replace(/=/g,"")}n(td,"generateChallenge");async function Hr(e){if(e||(e=43),e<43||e>128)throw`Expected a length between 43 and 128. Received ${e}.`;let t=await ed(e),r=await td(t);return{code_verifier:t,code_challenge:r}}n(Hr,"pkceChallenge");Z();var j=Gn().superRefine((e,t)=>{if(!URL.canParse(e))return t.addIssue({code:Zn.custom,message:"URL must be parseable",fatal:!0}),Jn}).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"}),er=Ht({resource:l().url(),authorization_servers:_(j).optional(),jwks_uri:l().url().optional(),scopes_supported:_(l()).optional(),bearer_methods_supported:_(l()).optional(),resource_signing_alg_values_supported:_(l()).optional(),resource_name:l().optional(),resource_documentation:l().optional(),resource_policy_uri:l().url().optional(),resource_tos_uri:l().url().optional(),tls_client_certificate_bound_access_tokens:se().optional(),authorization_details_types_supported:_(l()).optional(),dpop_signing_alg_values_supported:_(l()).optional(),dpop_bound_access_tokens_required:se().optional()}),mt=Ht({issuer:l(),authorization_endpoint:j,token_endpoint:j,registration_endpoint:j.optional(),scopes_supported:_(l()).optional(),response_types_supported:_(l()),response_modes_supported:_(l()).optional(),grant_types_supported:_(l()).optional(),token_endpoint_auth_methods_supported:_(l()).optional(),token_endpoint_auth_signing_alg_values_supported:_(l()).optional(),service_documentation:j.optional(),revocation_endpoint:j.optional(),revocation_endpoint_auth_methods_supported:_(l()).optional(),revocation_endpoint_auth_signing_alg_values_supported:_(l()).optional(),introspection_endpoint:l().optional(),introspection_endpoint_auth_methods_supported:_(l()).optional(),introspection_endpoint_auth_signing_alg_values_supported:_(l()).optional(),code_challenge_methods_supported:_(l()).optional(),client_id_metadata_document_supported:se().optional()}),rd=Ht({issuer:l(),authorization_endpoint:j,token_endpoint:j,userinfo_endpoint:j.optional(),jwks_uri:j,registration_endpoint:j.optional(),scopes_supported:_(l()).optional(),response_types_supported:_(l()),response_modes_supported:_(l()).optional(),grant_types_supported:_(l()).optional(),acr_values_supported:_(l()).optional(),subject_types_supported:_(l()),id_token_signing_alg_values_supported:_(l()),id_token_encryption_alg_values_supported:_(l()).optional(),id_token_encryption_enc_values_supported:_(l()).optional(),userinfo_signing_alg_values_supported:_(l()).optional(),userinfo_encryption_alg_values_supported:_(l()).optional(),userinfo_encryption_enc_values_supported:_(l()).optional(),request_object_signing_alg_values_supported:_(l()).optional(),request_object_encryption_alg_values_supported:_(l()).optional(),request_object_encryption_enc_values_supported:_(l()).optional(),token_endpoint_auth_methods_supported:_(l()).optional(),token_endpoint_auth_signing_alg_values_supported:_(l()).optional(),display_values_supported:_(l()).optional(),claim_types_supported:_(l()).optional(),claims_supported:_(l()).optional(),service_documentation:l().optional(),claims_locales_supported:_(l()).optional(),ui_locales_supported:_(l()).optional(),claims_parameter_supported:se().optional(),request_parameter_supported:se().optional(),request_uri_parameter_supported:se().optional(),require_request_uri_registration:se().optional(),op_policy_uri:j.optional(),op_tos_uri:j.optional(),client_id_metadata_document_supported:se().optional()}),tr=ye({...rd.shape,...mt.pick({code_challenge_methods_supported:!0}).shape}),$e=ye({access_token:l(),id_token:l().optional(),token_type:l(),expires_in:Kn.number().optional(),scope:l().optional(),refresh_token:l().optional()}).strip(),Zo=ye({error:l(),error_description:l().optional(),error_uri:l().optional()}),$o=j.optional().or($n("").transform(()=>{})),nd=ye({redirect_uris:_(j),token_endpoint_auth_method:l().optional(),grant_types:_(l()).optional(),response_types:_(l()).optional(),client_name:l().optional(),client_uri:j.optional(),logo_uri:$o,scope:l().optional(),contacts:_(l()).optional(),tos_uri:$o,policy_uri:l().optional(),jwks_uri:j.optional(),jwks:Fn().optional(),software_id:l().optional(),software_version:l().optional(),software_statement:l().optional()}).strip(),rr=ye({client_id:l(),client_secret:l().optional(),client_id_issued_at:Sr().optional(),client_secret_expires_at:Sr().optional()}).strip(),ft=nd.merge(rr),$h=ye({error:l(),error_description:l().optional()}).strip(),Zh=ye({token:l(),token_type_hint:l().optional()}).strip();function Ko(e){let t=typeof e=="string"?new URL(e):new URL(e.href);return t.hash="",t}n(Ko,"resourceUrlFromServerUrl");function Wo({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(Wo,"checkResourceAllowed");var A=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}},ht=class extends A{static{n(this,"InvalidRequestError")}};ht.errorCode="invalid_request";var Ue=class extends A{static{n(this,"InvalidClientError")}};Ue.errorCode="invalid_client";var Pe=class extends A{static{n(this,"InvalidGrantError")}};Pe.errorCode="invalid_grant";var Ee=class extends A{static{n(this,"UnauthorizedClientError")}};Ee.errorCode="unauthorized_client";var gt=class extends A{static{n(this,"UnsupportedGrantTypeError")}};gt.errorCode="unsupported_grant_type";var yt=class extends A{static{n(this,"InvalidScopeError")}};yt.errorCode="invalid_scope";var _t=class extends A{static{n(this,"AccessDeniedError")}};_t.errorCode="access_denied";var pe=class extends A{static{n(this,"ServerError")}};pe.errorCode="server_error";var wt=class extends A{static{n(this,"TemporarilyUnavailableError")}};wt.errorCode="temporarily_unavailable";var Rt=class extends A{static{n(this,"UnsupportedResponseTypeError")}};Rt.errorCode="unsupported_response_type";var bt=class extends A{static{n(this,"UnsupportedTokenTypeError")}};bt.errorCode="unsupported_token_type";var It=class extends A{static{n(this,"InvalidTokenError")}};It.errorCode="invalid_token";var St=class extends A{static{n(this,"MethodNotAllowedError")}};St.errorCode="method_not_allowed";var Ct=class extends A{static{n(this,"TooManyRequestsError")}};Ct.errorCode="too_many_requests";var Oe=class extends A{static{n(this,"InvalidClientMetadataError")}};Oe.errorCode="invalid_client_metadata";var vt=class extends A{static{n(this,"InsufficientScopeError")}};vt.errorCode="insufficient_scope";var At=class extends A{static{n(this,"InvalidTargetError")}};At.errorCode="invalid_target";var Vo={[ht.errorCode]:ht,[Ue.errorCode]:Ue,[Pe.errorCode]:Pe,[Ee.errorCode]:Ee,[gt.errorCode]:gt,[yt.errorCode]:yt,[_t.errorCode]:_t,[pe.errorCode]:pe,[wt.errorCode]:wt,[Rt.errorCode]:Rt,[bt.errorCode]:bt,[It.errorCode]:It,[St.errorCode]:St,[Ct.errorCode]:Ct,[Oe.errorCode]:Oe,[vt.errorCode]:vt,[At.errorCode]:At};function od(e){return["client_secret_basic","client_secret_post","none"].includes(e)}n(od,"isClientAuthMethod");var Br="code",Lr="S256";function id(e,t){let r=e.client_secret!==void 0;return"token_endpoint_auth_method"in e&&e.token_endpoint_auth_method&&od(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(id,"selectClientAuthMethod");function ad(e,t,r,o){let{client_id:i,client_secret:a}=t;switch(e){case"client_secret_basic":sd(i,a,r);return;case"client_secret_post":cd(i,a,o);return;case"none":dd(i,o);return;default:throw new Error(`Unsupported client authentication method: ${e}`)}}n(ad,"applyClientAuthentication");function sd(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(sd,"applyBasicAuth");function cd(e,t,r){r.set("client_id",e),t&&r.set("client_secret",t)}n(cd,"applyPostAuth");function dd(e,t){t.set("client_id",e)}n(dd,"applyPublicAuth");async function Xo(e){let t=e instanceof Response?e.status:void 0,r=e instanceof Response?await e.text():e;try{let o=Zo.parse(JSON.parse(r)),{error:i,error_description:a,error_uri:c}=o,s=Vo[i]||pe;return new s(a||"",c)}catch(o){let i=`${t?`HTTP ${t}: `:""}Invalid OAuth error response: ${o}. Raw body: ${r}`;return new pe(i)}}n(Xo,"parseErrorResponse");async function Gr(e,t){try{return await Nr(e,t)}catch(r){if(r instanceof Ue||r instanceof Ee)return await e.invalidateCredentials?.("all"),await Nr(e,t);if(r instanceof Pe)return await e.invalidateCredentials?.("tokens"),await Nr(e,t);throw r}}n(Gr,"auth");async function Nr(e,{serverUrl:t,authorizationCode:r,scope:o,resourceMetadataUrl:i,fetchFn:a}){let c=await e.discoveryState?.(),s,u,p,f=i;if(!f&&c?.resourceMetadataUrl&&(f=new URL(c.resourceMetadataUrl)),c?.authorizationServerUrl){if(u=c.authorizationServerUrl,s=c.resourceMetadata,p=c.authorizationServerMetadata??await ti(u,{fetchFn:a}),!s)try{s=await ei(t,{resourceMetadataUrl:f},a)}catch{}(p!==c.authorizationServerMetadata||s!==c.resourceMetadata)&&await e.saveDiscoveryState?.({authorizationServerUrl:String(u),resourceMetadataUrl:f?.toString(),resourceMetadata:s,authorizationServerMetadata:p})}else{let E=await hd(t,{resourceMetadataUrl:f,fetchFn:a});u=E.authorizationServerUrl,p=E.authorizationServerMetadata,s=E.resourceMetadata,await e.saveDiscoveryState?.({authorizationServerUrl:String(u),resourceMetadataUrl:f?.toString(),resourceMetadata:s,authorizationServerMetadata:p})}let w=await ud(t,e,s),U=o||s?.scopes_supported?.join(" ")||e.clientMetadata.scope,y=await Promise.resolve(e.clientInformation());if(!y){if(r!==void 0)throw new Error("Existing OAuth client information is required when exchanging an authorization code");let E=p?.client_id_metadata_document_supported===!0,D=e.clientMetadataUrl;if(D&&!Fr(D))throw new Oe(`clientMetadataUrl must be a valid HTTPS URL with a non-root pathname, got: ${D}`);if(E&&D)y={client_id:D},await e.saveClientInformation?.(y);else{if(!e.saveClientInformation)throw new Error("OAuth client information must be saveable for dynamic registration");let zn=await Rd(u,{metadata:p,clientMetadata:e.clientMetadata,scope:U,fetchFn:a});await e.saveClientInformation(zn),y=zn}}let P=!e.redirectUrl;if(r!==void 0||P){let E=await wd(e,u,{metadata:p,resource:w,authorizationCode:r,fetchFn:a});return await e.saveTokens(E),"AUTHORIZED"}let x=await e.tokens();if(x?.refresh_token)try{let E=await _d(u,{metadata:p,clientInformation:y,refreshToken:x.refresh_token,resource:w,addClientAuthentication:e.addClientAuthentication,fetchFn:a});return await e.saveTokens(E),"AUTHORIZED"}catch(E){if(!(!(E instanceof A)||E instanceof pe))throw E}let z=e.state?await e.state():void 0,{authorizationUrl:ze,codeVerifier:X}=await gd(u,{metadata:p,clientInformation:y,state:z,redirectUrl:e.redirectUrl,scope:U,resource:w});return await e.saveCodeVerifier(X),await e.redirectToAuthorization(ze),"REDIRECT"}n(Nr,"authInternal");function Fr(e){if(!e)return!1;try{let t=new URL(e);return t.protocol==="https:"&&t.pathname!=="/"}catch{return!1}}n(Fr,"isHttpsUrl");async function ud(e,t,r){let o=Ko(e);if(t.validateResourceURL)return await t.validateResourceURL(o,r?.resource);if(r){if(!Wo({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(ud,"selectResourceURL");function Qo(e){let t=e.headers.get("WWW-Authenticate");if(!t)return{};let[r,o]=t.split(" ");if(r.toLowerCase()!=="bearer"||!o)return{};let i=Jr(e,"resource_metadata")||void 0,a;if(i)try{a=new URL(i)}catch{}let c=Jr(e,"scope")||void 0,s=Jr(e,"error")||void 0;return{resourceMetadataUrl:a,scope:c,error:s}}n(Qo,"extractWWWAuthenticateParams");function Jr(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(Jr,"extractFieldFromWwwAuth");async function ei(e,t,r=fetch){let o=await md(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 er.parse(await o.json())}n(ei,"discoverOAuthProtectedResourceMetadata");async function $r(e,t,r=fetch){try{return await r(e,{headers:t})}catch(o){if(o instanceof TypeError)return t?$r(e,void 0,r):void 0;throw o}}n($r,"fetchWithCorsRetry");function ld(e,t="",r={}){return t.endsWith("/")&&(t=t.slice(0,-1)),r.prependPathname?`${t}/.well-known/${e}`:`/.well-known/${e}${t}`}n(ld,"buildWellKnownPath");async function Yo(e,t,r=fetch){return await $r(e,{"MCP-Protocol-Version":t},r)}n(Yo,"tryMetadataDiscovery");function pd(e,t){return!e||e.status>=400&&e.status<500&&t!=="/"}n(pd,"shouldAttemptFallback");async function md(e,t,r,o){let i=new URL(e),a=o?.protocolVersion??Cr,c;if(o?.metadataUrl)c=new URL(o.metadataUrl);else{let u=ld(t,i.pathname);c=new URL(u,o?.metadataServerUrl??i),c.search=i.search}let s=await Yo(c,a,r);if(!o?.metadataUrl&&pd(s,i.pathname)){let u=new URL(`/.well-known/${t}`,i);s=await Yo(u,a,r)}return s}n(md,"discoverMetadataWithFallback");function fd(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(fd,"buildDiscoveryUrls");async function ti(e,{fetchFn:t=fetch,protocolVersion:r=Cr}={}){let o={"MCP-Protocol-Version":r,Accept:"application/json"},i=fd(e);for(let{url:a,type:c}of i){let s=await $r(a,o,t);if(s){if(!s.ok){if(await s.body?.cancel(),s.status>=400&&s.status<500)continue;throw new Error(`HTTP ${s.status} trying to load ${c==="oauth"?"OAuth":"OpenID provider"} metadata from ${a}`)}return c==="oauth"?mt.parse(await s.json()):tr.parse(await s.json())}}}n(ti,"discoverAuthorizationServerMetadata");async function hd(e,t){let r,o;try{r=await ei(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 ti(o,{fetchFn:t?.fetchFn});return{authorizationServerUrl:o,authorizationServerMetadata:i,resourceMetadata:r}}n(hd,"discoverOAuthServerInfo");async function gd(e,{metadata:t,clientInformation:r,redirectUrl:o,scope:i,state:a,resource:c}){let s;if(t){if(s=new URL(t.authorization_endpoint),!t.response_types_supported.includes(Br))throw new Error(`Incompatible auth server: does not support response type ${Br}`);if(t.code_challenge_methods_supported&&!t.code_challenge_methods_supported.includes(Lr))throw new Error(`Incompatible auth server: does not support code challenge method ${Lr}`)}else s=new URL("/authorize",e);let u=await Hr(),p=u.code_verifier,f=u.code_challenge;return s.searchParams.set("response_type",Br),s.searchParams.set("client_id",r.client_id),s.searchParams.set("code_challenge",f),s.searchParams.set("code_challenge_method",Lr),s.searchParams.set("redirect_uri",String(o)),a&&s.searchParams.set("state",a),i&&s.searchParams.set("scope",i),i?.includes("offline_access")&&s.searchParams.append("prompt","consent"),c&&s.searchParams.set("resource",c.href),{authorizationUrl:s,codeVerifier:p}}n(gd,"startAuthorization");function yd(e,t,r){return new URLSearchParams({grant_type:"authorization_code",code:e,code_verifier:t,redirect_uri:String(r)})}n(yd,"prepareAuthorizationCodeRequest");async function ri(e,{metadata:t,tokenRequestParams:r,clientInformation:o,addClientAuthentication:i,resource:a,fetchFn:c}){let s=t?.token_endpoint?new URL(t.token_endpoint):new URL("/token",e),u=new Headers({"Content-Type":"application/x-www-form-urlencoded",Accept:"application/json"});if(a&&r.set("resource",a.href),i)await i(u,r,s,t);else if(o){let f=t?.token_endpoint_auth_methods_supported??[],w=id(o,f);ad(w,o,u,r)}let p=await(c??fetch)(s,{method:"POST",headers:u,body:r});if(!p.ok)throw await Xo(p);return $e.parse(await p.json())}n(ri,"executeTokenRequest");async function _d(e,{metadata:t,clientInformation:r,refreshToken:o,resource:i,addClientAuthentication:a,fetchFn:c}){let s=new URLSearchParams({grant_type:"refresh_token",refresh_token:o}),u=await ri(e,{metadata:t,tokenRequestParams:s,clientInformation:r,addClientAuthentication:a,resource:i,fetchFn:c});return{refresh_token:o,...u}}n(_d,"refreshAuthorization");async function wd(e,t,{metadata:r,resource:o,authorizationCode:i,fetchFn:a}={}){let c=e.clientMetadata.scope,s;if(e.prepareTokenRequest&&(s=await e.prepareTokenRequest(c)),!s){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 p=await e.codeVerifier();s=yd(i,p,e.redirectUrl)}let u=await e.clientInformation();return ri(t,{metadata:r,tokenRequestParams:s,clientInformation:u??void 0,addClientAuthentication:e.addClientAuthentication,resource:o,fetchFn:a})}n(wd,"fetchToken");async function Rd(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 c=await(i??fetch)(a,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...r,...o!==void 0?{scope:o}:{}})});if(!c.ok)throw await Xo(c);return ft.parse(await c.json())}n(Rd,"registerClient");var Zr="zuplo.com",bd=new Set(["co.jp","co.kr","co.nz","co.uk","com.au","com.br","com.cn","com.mx","com.sg","co.in"]),Id=[".example.test",".example.com",".example.org",".invalid",".localhost",".test"];function ni(e){return`https://www.google.com/s2/favicons?domain=${e}&sz=128`}n(ni,"s2FaviconHref");function Sd(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(Sd,"strictFaviconHref");var nr=ni(Zr);function Kr(e){let t=e.toLowerCase();return t===Zr||t==="zuplo.app"||t==="zuplo.dev"||t.endsWith(".zuplo.app")||t.endsWith(".zuplo.dev")?ni(Zr):Sd(e)}n(Kr,"resolveIconHref");function Cd(e){try{return new URL(`http://${e}`).hostname}catch{return e}}n(Cd,"hostnameFromHost");function vd(e){return e==="localhost"||e.includes(":")||/^\d{1,3}(?:\.\d{1,3}){3}$/.test(e)}n(vd,"isLocalOrAddressHost");function Ad(e){let t=Cd(e).toLowerCase().replace(/\.$/,"");if(vd(t)||Id.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=bd.has(o)?3:2;return r.slice(-i).join(".")}n(Ad,"inferFaviconDomain");function Wr(e){return{src:Kr(Ad(e)),mimeType:"image/png",sizes:["128x128"]}}n(Wr,"resolveMcpFaviconIcon");function or(e){try{return Wr(new URL(e).host)}catch{return}}n(or,"resolveMcpFaviconIconFromUrl");function Ie(e){let t=ee().connectionsById.get(e);if(!t)throw new B(`Unknown upstream server "${e}". Check the route's MCP upstream policy and ensure policies.json declares a matching upstream connection.`);return{displayName:t.displayName,description:t.description,serverInfo:t.serverInfo,transport:{baseUrl:t.mcpUrl,resourceMetadataUrl:t.protectedResourceMetadataUrl}}}n(Ie,"getUpstreamServerConfig");function ir(e){let t=ee().connectionsById.get(e.upstreamServerId);if(!t||t.authProfileId!==e.authProfileId)throw new B(`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.authConfig}n(ir,"getUpstreamAuthConfig");function Ze(e,t){let r=ir({upstreamServerId:e,authProfileId:t});if(r.mode!=="shared-oauth"&&r.mode!=="user-oauth")throw new B(`Upstream server "${e}" does not use upstream OAuth. Select authMode "shared-oauth" or "user-oauth" before starting an upstream OAuth connection flow.`);return r.oauth}n(Ze,"requireUpstreamOAuthConfig");function oi(e,t){let r=ir({upstreamServerId:e,authProfileId:t});if(r.mode!=="id-jag")throw new B(`Upstream server "${e}" does not use upstream ID-JAG. Select authMode "id-jag" before requesting an upstream XAA token exchange.`);return r.idJag}n(oi,"requireUpstreamIdJagConfig");function ii(e,t){if(!t)return;if(t.aborted){e.abort(t.reason);return}let r=n(()=>e.abort(t.reason),"abort");return t.addEventListener("abort",r,{once:!0}),()=>t.removeEventListener("abort",r)}n(ii,"mergeAbortSignals");async function xd(e){try{await e.cancel()}catch{}}n(xd,"cancelReader");async function ar(e,t){if(!e)return new Uint8Array;let r=e.getReader(),o=[],i=0,a=await r.read();for(;!a.done;){let u=a.value;if(i+=u.byteLength,i>t.maxBytes)throw await xd(r),t.createLimitError();o.push(u),a=await r.read()}let c=new Uint8Array(i),s=0;for(let u of o)c.set(u,s),s+=u.byteLength;return c}n(ar,"readBoundedByteStream");var kd=2,Td=1024*1024,Ud=1e4,Pd=new Set([301,302,303,307,308]),Ed=["authorization","proxy-authorization","cookie","cookie2"];function Vr(e){return typeof e=="string"?e:e instanceof URL?e.toString():e.url}n(Vr,"readRequestUrl");function Ke(e,t){return t?.method!==void 0?t.method.toUpperCase():e instanceof Request?e.method.toUpperCase():"GET"}n(Ke,"readRequestMethod");function Od(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 new h({message:"Outbound response exceeded the maximum allowed size.",extensionMembers:{[g]:r}})}n(Od,"assertContentLengthWithinLimit");async function qd(e,t,r){return Od(e,t,r),ar(e.body,{maxBytes:t,createLimitError:n(()=>new h({message:"Outbound response exceeded the maximum allowed size.",extensionMembers:{[g]:r}}),"createLimitError")})}n(qd,"readBoundedResponseBody");function Md(e,t){let r=new ArrayBuffer(t.byteLength);return new Uint8Array(r).set(t),new Response(r,{status:e.status,statusText:e.statusText,headers:e.headers})}n(Md,"responseFromBufferedBody");function Dd(e,t){if(!Pd.has(e.status))return;let r=e.headers.get("location");if(r)return new URL(r,t).toString()}n(Dd,"resolveRedirectUrl");function ai(e,t){try{return t.validateUrl(e)}catch(r){throw new h({message:"Outbound URL was not allowed.",extensionMembers:{[g]:t.problemCode}},{cause:r})}}n(ai,"validateOutboundUrl");function jd(e,t){throw e instanceof h&&Bt(e.extensionMembers?.[g])?e:new h({message:"Outbound fetch failed.",extensionMembers:{[g]:t}},{cause:e})}n(jd,"normalizeFetchError");function xt(e,t){if(e===void 0)return;let r={event:t.event,code:t.problemCode,method:t.method};if(t.host!==void 0&&(r.host=t.host),t.extra!==void 0)for(let[o,i]of Object.entries(t.extra))i!==void 0&&(r[o]=i);t.error!==void 0&&N(r,"error",t.error),e.log.warn(r,"Outbound HTTP exchange rejected")}n(xt,"logOutboundFailure");async function zd(e,t,r,o,i,a,c){let s=Ke(r,o);try{return await t(r,o)}catch(u){let p=u instanceof DOMException&&u.name==="AbortError";xt(e,{event:p?"outbound_fetch_aborted":"outbound_fetch_failed",problemCode:i,method:s,host:O(a),error:u,extra:{abortReason:c()}}),jd(u,i)}}n(zd,"fetchWithNormalizedError");function Hd(e){if(e.redirects>=e.maxRedirects)throw new h({message:"Outbound redirects exceeded the maximum allowed depth.",extensionMembers:{[g]:e.problemCode}});if(e.method!=="GET"&&e.method!=="HEAD")throw new h({message:"Outbound redirect after a non-idempotent request was blocked.",extensionMembers:{[g]:e.problemCode}})}n(Hd,"assertRedirectAllowed");function Bd(e,t){let r=new Headers(e);for(let o of Ed)r.delete(o);for(let o of t)r.delete(o);return r}n(Bd,"stripCrossOriginHeaders");function Ld(e,t,r,o,i){let a={...e,method:t,redirect:"manual",signal:r};return o&&(a.headers=Bd(e.headers,i)),a}n(Ld,"buildRedirectInit");function Nd(e,t,r){let o={...t,redirect:"manual",signal:r};return o.headers===void 0&&e instanceof Request&&(o.headers=e.headers),o}n(Nd,"buildInitialRequestInit");function Jd(e){let t=Ke(e.currentInput,e.currentInit);Hd({redirects:e.redirects,maxRedirects:e.maxRedirects,method:t,problemCode:e.problemCode});let r=ai(e.redirectUrl,{problemCode:e.problemCode,validateUrl:e.validateUrl}),o=new URL(e.currentUrl),i=r.origin!==o.origin,a=r.toString();return{currentInput:a,currentUrl:a,currentInit:Ld(e.currentInit,t,e.signal,i,e.additionalCrossOriginStrippedHeaders),redirects:e.redirects+1}}n(Jd,"followRedirect");async function Yr(e,t,r){let o=r.problemCode??"invalid_request",i=r.maxRedirects??kd,a=r.maxResponseBytes??Td,c=r.timeoutMs??Ud,s=r.fetchImpl??fetch,u=r.additionalCrossOriginStrippedHeaders??[],p=r.context,f=new AbortController,w=ii(f,t.signal),U=!1,y=setTimeout(()=>{U=!0,f.abort()},c),P=e,x=Nd(e,t,f.signal),z;try{z=ai(Vr(e),{problemCode:o,validateUrl:r.validateUrl}).toString()}catch(X){throw xt(p,{event:"outbound_url_blocked",problemCode:o,method:Ke(e,t),host:O(Vr(e)),error:X}),clearTimeout(y),w?.(),X}let ze=0;try{for(;;){let X=await zd(p,s,P,x,o,z,()=>U?`timeout_after_${c}ms`:void 0),E=Dd(X,z);if(E!==void 0)try{let D=Jd({currentInput:P,currentInit:x,currentUrl:z,redirectUrl:E,redirects:ze,maxRedirects:i,problemCode:o,validateUrl:r.validateUrl,signal:f.signal,additionalCrossOriginStrippedHeaders:u});P=D.currentInput,x=D.currentInit,z=D.currentUrl,ze=D.redirects;continue}catch(D){throw xt(p,{event:"outbound_redirect_blocked",problemCode:o,method:Ke(P,x),host:O(z),error:D,extra:{redirects:ze,maxRedirects:i,redirectTargetHost:O(E)}}),D}try{return Md(X,await qd(X,a,o))}catch(D){throw xt(p,{event:"outbound_response_size_exceeded",problemCode:o,method:Ke(P,x),host:O(z),error:D,extra:{maxResponseBytes:a,status:X.status}}),D}}}finally{clearTimeout(y),w?.()}}n(Yr,"runSafeOutboundExchange");async function kt(e,t,r){let o=await Yr(e,t,r);try{return{response:o,json:await o.clone().json()}}catch(i){throw xt(r.context,{event:"outbound_json_parse_failed",problemCode:r.problemCode??"invalid_request",method:Ke(e,t),host:O(Vr(e)),error:i,extra:{status:o.status,contentType:o.headers.get("content-type")??void 0}}),new h({message:"Outbound JSON response could not be parsed.",extensionMembers:{[g]:r.problemCode??"invalid_request"}},{cause:i})}}n(kt,"runSafeOutboundJsonExchange");function si(e,t={},r={}){return Yr(e,t,{...r,validateUrl:lt})}n(si,"fetchConfiguredOutbound");function ci(e,t={},r={}){return kt(e,t,{...r,validateUrl:lt})}n(ci,"fetchConfiguredOutboundJson");function sr(e,t={},r={}){return kt(e,t,{...r,validateUrl:Uo})}n(sr,"fetchIdentityProviderJson");function di(e,t={},r={}){return kt(e,t,{...r,validateUrl:Wt})}n(di,"fetchCimdClientMetadataJson");function ui(e,t={},r={}){return kt(e,t,{...r,validateUrl:pt})}n(ui,"fetchCimdClientJwksJson");Z();import{errors as gi,jwtVerify as yi,SignJWT as _i}from"jose";var $="zuplo-mcp-gateway",W=$,V="HS256";import{base64url as Gd}from"jose";var Fd=new TextEncoder,$d="MCP gateway could not initialize secure key material.",Zd=32,li=new Map,pi=new Map,Kd;function Wd(){return Kd??Hn.instance.authPrivateKey}n(Wd,"readAuthPrivateKey");function mi(e){return new Q($d,e===void 0?void 0:{cause:e})}n(mi,"createGeneratedKeyMaterialError");function fi(e,t){let r=Gd.decode(t);if(r.byteLength!==Zd)throw new Error(`Generated deployment auth key ${e} is invalid.`);return r}n(fi,"decodeJwkKeyField");function Vd(e){let t=Wd();if(!t)throw mi();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=fi("d",r.d);fi("x",r.x);let i=Fd.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 mi(r)}}n(Vd,"decodeGeneratedKeyMaterial");function Yd(e){let t=li.get(e);return t||(t=Vd(e),li.set(e,t)),t}n(Yd,"getMasterKeyMaterial");async function oe(e){let t=pi.get(e.purpose);if(t!==void 0)return t;let r=await e.derive(Yd(e.keyMaterialPurpose));return pi.set(e.purpose,r),r}n(oe,"readCachedDerivedKey");var Xd="SHA-256",Qd=32,eu="zuplo-mcp-gateway:",tu=new TextEncoder,hi=new WeakMap;async function Se(e,t){let r=hi.get(e);r||(r=new Map,hi.set(e,r));let o=r.get(t);if(o)return o;let i=await ru(e,t);return r.set(t,i),i}n(Se,"deriveGatewaySigningKey");async function ru(e,t){let r=G(e),o=await crypto.subtle.importKey("raw",r,{name:"HKDF"},!1,["deriveBits"]),i=tu.encode(`${eu}${t}`),a=await crypto.subtle.deriveBits({name:"HKDF",hash:Xd,salt:new Uint8Array,info:G(i)},o,Qd*8);return new Uint8Array(a)}n(ru,"hkdfExpand");var wi=900,nu=900,ou=po.extend({id:Mo}),iu=ou.extend({exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),Ri=vr.extend({id:Do,purpose:d.literal("browser_connect")}),au=vr.extend({purpose:d.literal("browser_connect")}),su=Ri.extend({exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),bi=wi*1e3;async function Ii(){return oe({purpose:"oauth-state",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>Se(e,"oauth-state"),"derive")})}n(Ii,"getOAuthStateKey");async function Si(){return oe({purpose:"browser-connect",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>Se(e,"browser-connect"),"derive")})}n(Si,"getBrowserConnectKey");async function Ci(e){let t=Math.floor(Date.now()/1e3)+wi;return new _i(e).setProtectedHeader({alg:V,typ:"JWT"}).setIssuer($).setAudience(W).setIssuedAt().setExpirationTime(t).sign(await Ii())}n(Ci,"signOAuthState");async function cr(e){try{let{payload:t}=await yi(e,await Ii(),{algorithms:[V],issuer:$,audience:W});return iu.parse(t)}catch(t){throw t instanceof gi.JWTExpired?new h({message:"OAuth state has expired",extensionMembers:{[g]:"oauth_state_expired"}},{cause:t}):new h({message:"OAuth state could not be verified",extensionMembers:{[g]:"oauth_state_invalid"}},{cause:t})}}n(cr,"verifyOAuthState");async function vi(e){let t=Math.floor(Date.now()/1e3)+nu,r=au.parse(e),o=Ri.parse({...r,id:Ho()});return new _i(o).setProtectedHeader({alg:V,typ:"JWT"}).setIssuer($).setAudience(W).setIssuedAt().setExpirationTime(t).sign(await Si())}n(vi,"signBrowserConnectTicket");async function Ai(e){try{let{payload:t}=await yi(e,await Si(),{algorithms:[V],issuer:$,audience:W});return su.parse(t)}catch(t){throw t instanceof gi.JWTExpired?new h({message:"Browser connect ticket has expired",extensionMembers:{[g]:"oauth_state_expired"}},{cause:t}):new h({message:"Browser connect ticket could not be verified",extensionMembers:{[g]:"oauth_state_invalid"}},{cause:t})}}n(Ai,"verifyBrowserConnectTicket");async function xi(e){if((await b().consumeBrowserConnectTicket({id:e.id,expiresAt:I(new Date(e.exp*1e3)),now:I(new Date)})).kind==="consumed")throw new h({message:"Browser connect ticket has already been used",extensionMembers:{[g]:"oauth_state_reused"}})}n(xi,"consumeBrowserConnectTicket");function cu(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(cu,"buildConnectRequiredMessage");async function du(e){let t=q(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 vi({...dt(e),purpose:"browser_connect"})),r.toString()}n(du,"buildGatewayBrowserTicketUrl");function uu(e){return H().actionPath(`/auth/connections/${encodeURIComponent(e)}/connect`)}n(uu,"buildGatewayConnectPath");async function Xr(e){return du({...e,path:uu(e.upstreamServerId),redirect:!0})}n(Xr,"buildGatewayConnectUrl");async function dr(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 Xr(t),message:cu(e.upstreamDisplayName,e.subject,e.requiresReconsent),nextAction:"redirect"}}n(dr,"buildRedirectConnectRequiredResponse");function ki(e){return lu({...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(ki,"buildAdminConnectRequiredResponse");function lu(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(lu,"buildAdminSetupRequiredResponse");var Ti=12;async function Ui(e){let t=await crypto.subtle.digest("SHA-256",G(new TextEncoder().encode(e)));return Array.from(new Uint8Array(t)).map(r=>r.toString(16).padStart(2,"0")).join("")}n(Ui,"sha256Hex");async function We(e){if(e)return(await Ui(e)).slice(0,Ti)}n(We,"fingerprintSecret");async function Ve(e){let t=JSON.stringify([e.owner.mode,e.owner.mode==="user"?e.owner.subjectId:"",e.upstreamServerId,e.authProfileId]);return(await Ui(t)).slice(0,Ti)}n(Ve,"fingerprintConnectionIdentity");function Tt(e){return e?e.status!=="active"?"inactive":e.encryptedAccessToken?e.expiresAt&&new Date(e.expiresAt).getTime()<=Date.now()?"expired":"usable":"no_access_token":"no_connection"}n(Tt,"describeAccessTokenState");Z();var Pi=new Set(["client_id","code_challenge","code_challenge_method","display","login_hint","nonce","prompt","redirect_uri","response_mode","response_type","state"]);function pu(e,t){return e&&e.length>0?e.join(t):void 0}n(pu,"joinOAuthScopes");function mu(e){if(e?.authorization_endpoint===void 0)return e;let t=new URL(e.authorization_endpoint);for(let r of Pi)t.searchParams.delete(r);return{...e,authorization_endpoint:t.toString()}}n(mu,"sanitizeAuthorizationServerMetadata");function Ei(e){let t=mu(e.authorizationServerMetadata);return t===e.authorizationServerMetadata?e:{...e,authorizationServerMetadata:t}}n(Ei,"sanitizeOAuthDiscoveryState");function Oi(e){let t=new URL(e);for(let r of Pi){let o=t.searchParams.getAll(r);o.length<=1||(t.searchParams.delete(r),t.searchParams.set(r,o.at(-1)??""))}return t}n(Oi,"dedupeSingletonAuthorizationRequestParams");function ur(e){let t=new URL(e);return K(t)&&Vn(t.hostname)!=="localhost"&&(t.hostname="localhost"),t}n(ur,"normalizeLoopbackOAuthRedirectUri");function qi(e){return pu(e.state?.resourceMetadata?.scopes_supported,e.delimiter)}n(qi,"readProtectedResourceMetadataScope");function fu(e){return`Zuplo MCP Gateway - ${e}`}n(fu,"buildGatewayOAuthClientName");function hu(e,t){return e&&e.length>0?e.join(t):void 0}n(hu,"joinOAuthScopeList");function gu(e){if(e.clientRegistration.mode!=="auto")return hu(e.scopes,e.scopeDelimiter)}n(gu,"readPublicClientMetadataScope");function Qr(e){return new URL(H().actionPath(`/.well-known/oauth-client/${encodeURIComponent(e.upstreamServerId)}`),e.origin).toString()}n(Qr,"buildOAuthClientMetadataDocumentUrl");function en(e){let t=Ie(e.upstreamServerId);return{client_name:fu(t.displayName),client_uri:new URL("/",e.origin).toString(),redirect_uris:[e.redirectUri],grant_types:["authorization_code","refresh_token"],response_types:["code"],application_type:"web",...e.scope===void 0?{}:{scope:e.scope},token_endpoint_auth_method:"none"}}n(en,"buildGatewayOAuthClientMetadata");function Mi(e,t,r){let o=Ze(t,r),i=gu(o);return{client_id:Qr({origin:e,upstreamServerId:t}),...en({origin:e,upstreamServerId:t,redirectUri:ur(new URL(o.redirectPath,e)).toString(),scope:i})}}n(Mi,"buildOAuthClientMetadataDocument");Z();import{base64url as Ce}from"jose";var yu="SHA-256",Ye="AES-GCM",_u=12,rn="zuplo-secret",nn=1,Di="generated:auth_private_key:token-encryption",wu=d.object({version:d.literal(nn),keyId:d.literal(Di),algorithm:d.literal(Ye),iv:d.string().min(1),ciphertext:d.string().min(1)}).strict();async function tn(){return oe({purpose:"token-encryption",keyMaterialPurpose:"token-encryption",derive:n(async e=>{let t=await crypto.subtle.digest(yu,G(e));return crypto.subtle.importKey("raw",t,{name:Ye},!1,["encrypt","decrypt"])},"derive")})}n(tn,"getEncryptionKey");function ji(e){return G(new TextEncoder().encode(`${rn}:v${e.version}:${e.keyId}`))}n(ji,"getAssociatedData");function Ru(e){return`${rn}:v${e.version}:${Ce.encode(new TextEncoder().encode(JSON.stringify(e)))}`}n(Ru,"encodeEnvelope");function bu(e){let t=`${rn}:v${nn}:`;if(!e.startsWith(t))return;let r=e.slice(t.length),o=new TextDecoder().decode(Ce.decode(r));return wu.parse(JSON.parse(o))}n(bu,"decodeEnvelope");async function me(e){let t=await tn(),r=crypto.getRandomValues(new Uint8Array(_u)),o={version:nn,keyId:Di},i=await crypto.subtle.encrypt({name:Ye,iv:r,additionalData:ji(o)},t,new TextEncoder().encode(e));return Ru({...o,algorithm:Ye,iv:Ce.encode(r),ciphertext:Ce.encode(new Uint8Array(i))})}n(me,"encryptSecret");async function ve(e){let t=bu(e);if(t){let c=await tn(),s=await crypto.subtle.decrypt({name:Ye,iv:G(Ce.decode(t.iv)),additionalData:ji(t)},c,G(Ce.decode(t.ciphertext)));return new TextDecoder().decode(s)}let[r,o]=e.split(".");if(!r||!o)throw new Q("Encrypted payload is malformed");let i=await tn(),a=await crypto.subtle.decrypt({name:Ye,iv:G(Ce.decode(r))},i,G(Ce.decode(o)));return new TextDecoder().decode(a)}n(ve,"decryptSecret");var Iu=d.union([ft,rr]),Su=d.object({authorizationServerUrl:d.url(),resourceMetadataUrl:d.url().optional(),resourceMetadata:er.optional(),authorizationServerMetadata:d.union([mt,tr]).optional()}).passthrough(),Cu="Bearer",vu="__zuplo_refresh_only_upstream_access_token__";function Au(e){return e?e.split(/[,\s]+/).filter(Boolean):[]}n(Au,"splitScopes");function xu(e){return Be.parse(e)}n(xu,"parsePkceCodeVerifier");function ku(e){if(typeof e.expires_in=="number")return I(new Date(Date.now()+e.expires_in*1e3))}n(ku,"readTokenExpiry");async function Tu(e){if(e!==void 0)return me(JSON.stringify(e))}n(Tu,"encryptJson");async function Uu(e,t){if(!e)return;let r=await ve(e);try{return t.parse(JSON.parse(r))}catch(o){throw new h({message:"Stored upstream OAuth JSON state is invalid.",extensionMembers:{[g]:"oauth_state_invalid"}},{cause:o})}}n(Uu,"decryptJson");function Pu(e,t){return"redirect_uris"in e?e.redirect_uris.includes(t):!0}n(Pu,"clientInformationAllowsRedirectUri");function Eu(e){return e.clientMetadataUrl===void 0?"redirect_uris"in e.clientInformation:"redirect_uris"in e.clientInformation||e.clientInformation.client_id===e.clientMetadataUrl}n(Eu,"clientInformationMatchesCurrentClientMetadataUrl");function Ou(e){return e.clientMetadataUrl!==void 0&&!("redirect_uris"in e.clientInformation)&&e.clientInformation.client_id===e.clientMetadataUrl}n(Ou,"isUrlBasedClientInformation");function qu(e,t){return t===void 0?e:{...e,scope:t}}n(qu,"applyOAuthClientMetadataScope");function Mu(e,t){return qi({state:e,delimiter:t})}n(Mu,"readResourceMetadataScope");function Du(e,t){return e&&e.length>0?e.join(t):void 0}n(Du,"joinOAuthScopeList");function ju(e){let t;if(e.registration.tokenEndpointAuthMethod!=="none"&&(t=e.registration.clientSecret,!t))throw new B(`Manual OAuth registration for upstream "${e.upstreamServerId}" requires clientSecret. Set the env var that backs the client secret or use tokenEndpointAuthMethod "none".`);return ft.parse({...e.clientMetadata,client_id:e.registration.clientId,token_endpoint_auth_method:e.registration.tokenEndpointAuthMethod,...t===void 0?{}:{client_secret:t}})}n(ju,"buildManualOAuthClientInformation");function zu(e,t){let r=Qr({origin:new URL(t).origin,upstreamServerId:e});return Fr(r)?r:void 0}n(zu,"buildClientMetadataUrl");function Hu(e){for(let t of e)if(t!==void 0)return t}n(Hu,"firstDefined");function Bu(e){let t=Ze(e.target.upstreamServerId,e.target.authProfileId),r=Du(t.scopes,t.scopeDelimiter),o=en({origin:new URL(e.redirectUri).origin,upstreamServerId:e.target.upstreamServerId,redirectUri:e.redirectUri,scope:r});if(t.clientRegistration.mode==="manual")return{clientMetadata:o,configuredScope:r,scopeDelimiter:t.scopeDelimiter,configuredClientInformation:ju({clientMetadata:o,registration:t.clientRegistration,upstreamServerId:e.target.upstreamServerId})};let i=zu(e.target.upstreamServerId,e.redirectUri);return i===void 0?{clientMetadata:o,configuredScope:r,scopeDelimiter:t.scopeDelimiter}:{clientMetadata:o,configuredScope:r,scopeDelimiter:t.scopeDelimiter,clientMetadataUrl:i}}n(Bu,"buildInitialOAuthClientSetup");function Lu(e,t){if(t===void 0)return Hu([e.pendingState?.encryptedClientInformation,e.connectionMetadata?.encryptedClientInformation,e.connection?.metadata?.encryptedClientInformation])}n(Lu,"readEncryptedClientInformation");var qe=class{static{n(this,"UpstreamOAuthProvider")}clientMetadataUrl;target;redirectUriValue;returnOrigin;clientMetadataValue;configuredScope;scopeDelimiter;configuredClientInformation;challengeScope;inferredScope;authorizationUrlValue;connection;pendingState;encryptedClientInformation;cachedClientInformation;clientInformationLoaded=!1;cachedDiscoveryState;discoveryStateLoaded=!1;cachedTokens;tokensLoaded=!1;connectionFingerprintValue;usedRefreshTokenFingerprintValue;constructor(t){let r=Bu({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=Lu(t,this.configuredClientInformation)}get authorizationUrl(){return this.authorizationUrlValue}get usedRefreshTokenFingerprint(){return this.usedRefreshTokenFingerprintValue}async connectionFingerprint(){return this.connectionFingerprintValue===void 0&&(this.connectionFingerprintValue=await Ve({owner:this.target.owner,upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId})),this.connectionFingerprintValue}get redirectUrl(){return this.redirectUriValue}get clientMetadata(){return qu(this.clientMetadataValue,this.readEffectiveScope())}async state(){let t=await this.createPendingState();return Ci({id:t.id,...dt({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,J()?.info({event:"upstream_oauth_client_registered",upstreamServerId:this.target.upstreamServerId,clientId:"client_id"in t?t.client_id:void 0,redirectUriCount:"redirect_uris"in t?t.redirect_uris.length:void 0},"Upstream OAuth client registered for the gateway"),!Ou({clientInformation:t,clientMetadataUrl:this.clientMetadataUrl})&&(this.encryptedClientInformation=await Tu(t),await this.syncPendingState(!1)))}async discoveryState(){return this.readCachedDiscoveryState()}applyChallengeScope(t){this.challengeScope=t}async saveDiscoveryState(t){let r=Ei(Su.parse(t));this.cachedDiscoveryState=r,this.discoveryStateLoaded=!0,J()?.info({event:"upstream_oauth_discovery_resolved",upstreamServerId:this.target.upstreamServerId,authorizationServerHost:O(r.authorizationServerUrl),resourceMetadataHost:O(r.resourceMetadataUrl),resource:r.resourceMetadata?.resource,scopesSupportedCount:r.resourceMetadata?.scopes_supported?.length,hasResourceMetadata:r.resourceMetadata!==void 0},"Upstream OAuth discovery resolved authorization server and resource"),this.inferredScope=Mu(r,this.scopeDelimiter)}async tokens(){return this.loadStoredTokens()}async saveTokens(t){let r=$e.parse(t),o=this.target.owner.mode==="user"?this.target.owner.subjectId:void 0,i=this.connection,a=!r.refresh_token&&!!i?.encryptedRefreshToken,c=r.refresh_token?await me(r.refresh_token):this.connection?.encryptedRefreshToken;this.cachedTokens=r.refresh_token||!this.connection?.encryptedRefreshToken?r:$e.parse({...r,refresh_token:await ve(this.connection.encryptedRefreshToken)}),this.tokensLoaded=!0;let s={id:this.connection?.id??Vt(),ownerMode:this.target.owner.mode,subjectId:o,upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,status:"active",encryptedAccessToken:await me(r.access_token),encryptedRefreshToken:c,scopes:Au(r.scope??this.readEffectiveScope()),expiresAt:ku(r),metadata:this.readStoredOAuthPersistence(this.target.owner.mode==="shared"?this.target.initiatedBySubjectId:void 0)};this.connection=await b().upsertUpstreamConnection(s),J()?.info({event:"upstream_oauth_tokens_persisted",upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,ownerMode:this.target.owner.mode,connectionFingerprint:await this.connectionFingerprint(),connectionId:this.connection.id,hasRefreshToken:!!c,priorStatus:i?.status,priorUpdatedAt:i?.updatedAt,usedRefreshTokenFingerprint:this.usedRefreshTokenFingerprintValue,newRefreshTokenFingerprint:await We(r.refresh_token),reusedSnapshotRefreshToken:a,scopeCount:s.scopes.length,expiresAt:s.expiresAt},"Upstream OAuth tokens persisted; upstream connection is active")}async redirectToAuthorization(t){let r=Oi(t);this.authorizationUrlValue=r.toString()}async saveCodeVerifier(t){let r=await this.createPendingState();await this.persistPendingState({...r,codeVerifier:xu(t)})}async codeVerifier(){if(!this.pendingState?.codeVerifier)throw new h({message:"OAuth code verifier is missing",extensionMembers:{[g]:"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.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:zo(),...dt({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:I(new Date(Date.now()+bi)),redirectUri:this.redirectUriValue,...this.returnOrigin===void 0?{}:{returnOrigin:this.returnOrigin},encryptedClientInformation:this.encryptedClientInformation,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})}async loadPersistedClientInformation(){if(this.clientInformationLoaded)return this.cachedClientInformation;let t;try{t=await Uu(this.encryptedClientInformation,Iu)}catch{this.encryptedClientInformation=void 0,this.cachedClientInformation=void 0,this.clientInformationLoaded=!0,await this.syncPendingState(!1),await this.persistCredentialInvalidation(!1);return}if(t&&(!Pu(t,this.redirectUriValue)||!Eu({clientInformation:t,clientMetadataUrl:this.clientMetadataUrl}))){this.encryptedClientInformation=void 0,this.cachedClientInformation=void 0,this.clientInformationLoaded=!0,await this.syncPendingState(!1),await this.persistCredentialInvalidation(!1);return}return t===void 0&&this.pendingState?.codeVerifier!==void 0&&this.clientMetadataUrl!==void 0&&(t=rr.parse({client_id:this.clientMetadataUrl})),this.cachedClientInformation=t,this.clientInformationLoaded=!0,this.cachedClientInformation}async readCachedDiscoveryState(){if(this.discoveryStateLoaded)return this.cachedDiscoveryState;this.discoveryStateLoaded=!0}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"){J()?.debug({event:"upstream_oauth_tokens_not_loaded",upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,connectionFingerprint:await this.connectionFingerprint(),connectionId:this.connection?.id,status:this.connection?.status??"not_connected"},"Upstream OAuth tokens not loaded; connection is not active");return}let t=this.connection.encryptedAccessToken?await ve(this.connection.encryptedAccessToken):void 0,r=this.connection.encryptedRefreshToken?await ve(this.connection.encryptedRefreshToken):void 0;if(!t&&!r)return;let o=J();this.usedRefreshTokenFingerprintValue=o?await We(r):void 0,o?.debug({event:"upstream_oauth_tokens_loaded",upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,connectionFingerprint:await this.connectionFingerprint(),connectionId:this.connection.id,hasAccessToken:!!t,hasRefreshToken:!!r,usedRefreshTokenFingerprint:this.usedRefreshTokenFingerprintValue,expiresAt:this.connection.expiresAt},"Upstream OAuth tokens loaded from stored connection");let i=$e.parse({access_token:t??vu,token_type:Cu,refresh_token:r,scope:this.connection.scopes.length>0?this.connection.scopes.join(" "):void 0});return this.cachedTokens=i,i}async persistCredentialInvalidation(t){if(!this.connection)return;let r=this.connection.status,o=this.connection.updatedAt,i={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&&(i.status="reconsent_required",i.encryptedAccessToken=void 0,i.encryptedRefreshToken=void 0,i.scopes=[],i.expiresAt=void 0),i.metadata=this.readStoredOAuthPersistence(this.connection.metadata?.connectedBySubjectId),this.connection=await b().upsertUpstreamConnection(i);let a=J();if(a){let c={event:"upstream_oauth_credentials_invalidated",upstreamServerId:this.target.upstreamServerId,authProfileId:this.target.authProfileId,connectionFingerprint:await this.connectionFingerprint(),connectionId:this.connection.id,clearedTokens:t,priorStatus:r,newStatus:this.connection.status,priorUpdatedAt:o,usedRefreshTokenFingerprint:this.usedRefreshTokenFingerprintValue};t?a.warn(c,"Upstream OAuth credentials invalidated; connection now requires reconsent"):a.debug(c,"Upstream OAuth credential metadata rewritten")}}readStoredOAuthPersistence(t){if(!(!this.encryptedClientInformation&&!t))return{encryptedClientInformation:this.encryptedClientInformation,connectedBySubjectId:t}}};var Nu=3e4,Ju=256*1024,Gu=2,Fu="does not support dynamic client registration",$u=["Resource server does not implement OAuth 2.0 Protected Resource Metadata","trying to load well-known OAuth protected resource metadata"],Zu=["HTTP 403 Forbidden","Access Denied","permission to access"],Ku=new Set(["access_denied","invalid_client","invalid_grant","invalid_request","invalid_scope","invalid_target","unauthorized_client","unsupported_grant_type"]);function Wu(e){return e instanceof Error&&e.message.includes(Fu)}n(Wu,"isDynamicClientRegistrationUnsupported");function Vu(e){return e instanceof Error&&$u.some(t=>e.message.includes(t))}n(Vu,"isProtectedResourceMetadataUnavailable");function Yu(e){return e instanceof Error&&Zu.some(t=>e.message.includes(t))}n(Yu,"isUpstreamProviderAccessDenied");function Xu(e){return e instanceof A&&Ku.has(e.errorCode)}n(Xu,"isStoredConnectionReconsentError");function Qu(e){if(e.error instanceof h&&e.error.extensionMembers?.[g]!==void 0)return e.error;if(Wu(e.error))return new h({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:{[g]:"upstream_client_registration_required"}},{cause:e.error});if(Vu(e.error))return new h({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:{[g]:"upstream_oauth_discovery_unavailable"}},{cause:e.error});if(Yu(e.error))return new h({message:`The upstream provider denied access while connecting ${e.upstreamServerId}. Confirm the provider allows this gateway and its OAuth client, then retry.`,extensionMembers:{[g]:"upstream_provider_access_denied"}},{cause:e.error})}n(Qu,"mapUpstreamOAuthSetupError");function el(e){return typeof e=="string"||e instanceof URL?{url:new URL(e.toString())}:{method:e.method,url:new URL(e.url)}}n(el,"readOAuthFetchRequest");function tl(e,t){return(e.headers.get("content-type")??"").includes("json")||t.trimStart().startsWith("{")||t.trimStart().startsWith("[")}n(tl,"responseLooksJson");function rl(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(rl,"responseLooksHtml");function nl(e){let t=e.response.statusText?` ${e.response.statusText}`:"",r=e.response.headers.get("content-type")??"text/html";throw new h({message:`The upstream provider returned ${e.response.status}${t} (${r}) from ${e.request.url.toString()} while connecting ${e.upstreamServerId}.`,extensionMembers:{[g]:e.response.status===403?"upstream_provider_access_denied":"upstream_token_exchange_failed",[_e]:e.response.status,[Le]:r,[we]:e.request.url.toString(),[Ne]:e.body}})}n(nl,"throwUpstreamHtmlError");function ol(e){try{let t=JSON.parse(e);if(typeof t!="object"||t===null)return{};let r=t;return{error:typeof r.error=="string"?r.error:void 0,errorDescription:typeof r.error_description=="string"?r.error_description:void 0}}catch{return{}}}n(ol,"readUpstreamOAuthErrorBody");function il(e){let{error:t,errorDescription:r}=ol(e.body);e.log?.warn({event:"upstream_oauth_http_error",upstreamServerId:e.upstreamServerId,method:e.request.method??"GET",host:O(e.request.url),path:e.request.url.pathname,status:e.response.status,oauthError:t,oauthErrorDescription:r?.slice(0,256)},"Upstream OAuth HTTP request returned an error response")}n(il,"logUpstreamOAuthHttpError");function Hi(e){return async(t,r)=>{let o=el(t),i=J(),a=Date.now(),c=await si(t,r,{maxRedirects:Gu,maxResponseBytes:Ju,problemCode:"upstream_token_exchange_failed",timeoutMs:Nu}),s=await c.clone().text();if(i?.debug({event:"upstream_oauth_http_request",upstreamServerId:e,method:o.method??"GET",host:O(o.url),path:o.url.pathname,status:c.status,durationMs:Date.now()-a,responseChars:s.length},"Upstream OAuth HTTP request completed"),c.ok||il({log:i,upstreamServerId:e,request:o,response:c,body:s}),!c.ok&&rl(c,s)&&nl({upstreamServerId:e,request:o,response:c,body:s}),!tl(c,s))return c;try{JSON.parse(s)}catch(u){throw new h({message:`Upstream OAuth fetch ${o.url.origin}${o.url.pathname} for ${e} returned invalid JSON.`,extensionMembers:{[g]:"upstream_token_exchange_failed"}},{cause:u})}return c}}n(Hi,"createUpstreamOAuthFetch");function Bi(e){J()?.debug({event:e.phase==="authorize"?"upstream_oauth_authorize_started":"upstream_oauth_token_exchange_started",upstreamServerId:e.upstreamServerId,serverHost:O(e.serverUrl),resourceMetadataHost:O(e.resourceMetadataUrl),hasRequestedScope:e.requestedScope!==void 0},e.phase==="authorize"?"Upstream OAuth authorization flow started":"Upstream OAuth authorization-code exchange started")}n(Bi,"logUpstreamOAuthFlowStarted");function Li(e){let t={event:"upstream_oauth_flow_failed",phase:e.phase,upstreamServerId:e.upstreamServerId},r=O(e.serverUrl);r!==void 0&&(t.serverHost=r);let o=e.error instanceof h?e.error.extensionMembers?.[g]:void 0;typeof o=="string"&&(t.code=o),N(t,"error",e.error),J()?.warn(t,"Upstream OAuth flow failed before a connection was established")}n(Li,"logUpstreamOAuthFlowFailed");async function Ni(e,t){e.applyChallengeScope(t.requestedScope),Bi({phase:"authorize",...t});try{let r={serverUrl:t.serverUrl,resourceMetadataUrl:new URL(t.resourceMetadataUrl),fetchFn:Hi(t.upstreamServerId)};return t.requestedScope!==void 0&&(r.scope=t.requestedScope),await Gr(e,r)}catch(r){Li({phase:"authorize",upstreamServerId:t.upstreamServerId,serverUrl:t.serverUrl,error:r});let o=Qu({upstreamServerId:t.upstreamServerId,resourceMetadataUrl:t.resourceMetadataUrl,error:r});throw o!==void 0?o:r}}n(Ni,"runUpstreamOAuth");async function al(e,t){e.applyChallengeScope(t.requestedScope),Bi({phase:"token_exchange",...t});let r={serverUrl:t.serverUrl,authorizationCode:t.authorizationCode,resourceMetadataUrl:new URL(t.resourceMetadataUrl),fetchFn:Hi(t.upstreamServerId)};t.requestedScope!==void 0&&(r.scope=t.requestedScope);try{return await Gr(e,r)}catch(o){throw Li({phase:"token_exchange",upstreamServerId:t.upstreamServerId,serverUrl:t.serverUrl,error:o}),o}}n(al,"exchangeUpstreamAuthorizationCode");async function Ji(e,t){let r=await Ni(e,t);if(r==="REDIRECT"&&e.authorizationUrl)return e.authorizationUrl;throw r==="AUTHORIZED"?new h({message:`OAuth connect flow reused existing credentials instead of producing a redirect for ${t.upstreamServerId}`,extensionMembers:{[g]:"upstream_token_exchange_failed"}}):new h({message:`Unexpected OAuth result for ${t.upstreamServerId}: ${r}`,extensionMembers:{[g]:"upstream_token_exchange_failed"}})}n(Ji,"requireUpstreamAuthorizationRedirect");async function Gi(e){let t=Tt(e.connection),r=!!e.forceRefresh,o=!r&&t==="usable",i=J(),a=i?await Ve({owner:e.target.owner,upstreamServerId:e.target.upstreamServerId,authProfileId:e.target.authProfileId}):void 0;if(i?.debug({event:"upstream_oauth_refresh_decision",upstreamServerId:e.target.upstreamServerId,authProfileId:e.target.authProfileId,ownerMode:e.target.owner.mode,connectionFingerprint:a,connectionId:e.connection?.id,accessTokenState:t,forceRefresh:r,willRefresh:!o,expiresAt:e.connection?.expiresAt,connectionUpdatedAt:e.connection?.updatedAt},o?"Reusing stored upstream access token":"Refreshing upstream credential"),o)return{kind:"authorized",credential:{type:"mcp_oauth_provider",provider:e.provider}};let c;try{c=await Ni(e.provider,{upstreamServerId:e.target.upstreamServerId,serverUrl:e.serverUrl,resourceMetadataUrl:e.resourceMetadataUrl,...e.requestedScope===void 0?{}:{requestedScope:e.requestedScope}})}catch(s){if(e.connection===void 0||!Xu(s))throw s;return i?.warn({event:"upstream_oauth_connection_reconsent_required",upstreamServerId:e.target.upstreamServerId,authProfileId:e.target.authProfileId,oauthError:s.errorCode,connectionFingerprint:a,connectionId:e.connection.id,rejectedRefreshTokenFingerprint:e.provider.usedRefreshTokenFingerprint,connectionUpdatedAt:e.connection.updatedAt,connectionExpiresAt:e.connection.expiresAt},"Stored upstream OAuth connection was rejected by the upstream provider"),await e.provider.invalidateCredentials("all"),{kind:"connect_required",payload:await zi({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}})}}if(c==="AUTHORIZED")return{kind:"authorized",credential:{type:"mcp_oauth_provider",provider:e.provider}};if(c!=="REDIRECT")throw new h({message:`Unexpected OAuth result for ${e.target.upstreamServerId}: ${c}`,extensionMembers:{[g]:"upstream_token_exchange_failed"}});if(!e.provider.authorizationUrl)throw new h({message:`OAuth connect-required flow did not produce a redirect for ${e.target.upstreamServerId}`,extensionMembers:{[g]:"upstream_token_exchange_failed"}});return{kind:"connect_required",payload:await zi({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(Gi,"authorizeUpstreamOAuthSession");async function sl(e){let t=await cr(e.stateToken),r=await b().consumeUpstreamOAuthState({id:t.id,now:I(new Date)}),o=cl(r);return dl({storedState:o,signedState:t,upstreamServerId:e.upstreamServerId,callbackPath:new URL(e.request.url).pathname}),ul(o),o}n(sl,"consumeStoredCallbackState");function cl(e){switch(e.kind){case"consumed":throw new h({message:"OAuth state has already been used",extensionMembers:{[g]:"oauth_state_reused"}});case"missing":throw new h({message:"OAuth state is missing or expired",extensionMembers:{[g]:"oauth_state_expired"}});case"available":return e.record}}n(cl,"readConsumedCallbackState");function dl(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 h({message:"OAuth callback did not match the initiating request",extensionMembers:{[g]:"oauth_callback_mismatch"}})}n(dl,"assertStoredCallbackStateMatches");function ul(e){if(new Date(e.expiresAt).getTime()<=Date.now())throw new h({message:"OAuth state has expired",extensionMembers:{[g]:"oauth_state_expired"}})}n(ul,"assertStoredCallbackStateFresh");async function zi(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),ki(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),dr(t)}n(zi,"buildOAuthConnectRequiredResponse");async function Fi(e){let t=await sl({request:e.request,upstreamServerId:e.upstreamServerId,stateToken:e.stateToken}),r=Ft(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 qe(i),c=await al(a,{upstreamServerId:e.upstreamServerId,serverUrl:e.upstreamServerConfig.transport.baseUrl,authorizationCode:e.authorizationCode,resourceMetadataUrl:e.upstreamServerConfig.transport.resourceMetadataUrl});if(c==="AUTHORIZED")return t;throw c!=="REDIRECT"?new h({message:`Unexpected OAuth result for ${e.upstreamServerId}: ${c}`,extensionMembers:{[g]:"upstream_token_exchange_failed"}}):new h({message:`OAuth callback flow did not finish authorization for ${e.upstreamServerId}`,extensionMembers:{[g]:"upstream_token_exchange_failed"}})}n(Fi,"finishUpstreamOAuthCallback");Z();import{importPKCS8 as ll,SignJWT as pl}from"jose";var Zi=1e4,Ki=64*1024,Wi=2,ml=300,ne=d.string().min(1),fl=d.object({access_token:ne,issued_token_type:d.literal(xr),token_type:d.string().optional(),expires_in:d.number().int().positive().optional(),scope:ne.optional()}).passthrough(),hl=d.object({id_token:ne,token_type:ne.optional(),expires_in:d.number().int().positive().optional(),refresh_token:ne.optional(),scope:ne.optional()}).passthrough(),gl=d.object({access_token:ne,token_type:ne,expires_in:d.number().int().positive().optional(),scope:ne.optional(),resource:ne.optional(),refresh_token:ne.optional()}).passthrough();function $i(e){return encodeURIComponent(e).replace(/%20/g,"+")}n($i,"formEncodeClientCredential");function yl(e){return e.replaceAll("\\n",`
26
+ `)}n(yl,"normalizePem");async function _l(e){let t=e.clientAuth.algorithm??"RS256",r=e.clientAuth.expiresInSeconds??ml,o=await ll(yl(e.clientAuth.privateKeyPem),t),i={alg:t,typ:"JWT",...e.clientAuth.keyId===void 0?{}:{kid:e.clientAuth.keyId}};return new pl({jti:crypto.randomUUID()}).setProtectedHeader(i).setIssuer(e.clientAuth.clientId).setSubject(e.clientAuth.clientId).setAudience(e.clientAuth.audience??e.tokenUrl).setIssuedAt().setExpirationTime(`${r}s`).sign(o)}n(_l,"createPrivateKeyJwtClientAssertion");async function wl(e){switch(e.clientAuth.method){case"client_secret_post":e.form.set("client_id",e.clientAuth.clientId),e.form.set("client_secret",e.clientAuth.clientSecret);return;case"client_secret_basic":{let t=$i(e.clientAuth.clientId),r=$i(e.clientAuth.clientSecret);e.headers.authorization=`Basic ${btoa(`${t}:${r}`)}`;return}case"private_key_jwt":e.form.set("client_id",e.clientAuth.clientId),e.form.set("client_assertion_type",Zt),e.form.set("client_assertion",await _l({clientAuth:e.clientAuth,tokenUrl:e.tokenUrl}));return}}n(wl,"appendClientAuthentication");async function on(e){let t={"Content-Type":"application/x-www-form-urlencoded"};return await wl({form:e.form,headers:t,clientAuth:e.clientAuth,tokenUrl:e.tokenUrl}),{method:"POST",headers:t,body:e.form.toString()}}n(on,"buildFormRequest");function Vi(e){return(t,r)=>sr(t,r,{context:e,maxRedirects:Wi,maxResponseBytes:Ki,problemCode:"upstream_token_exchange_failed",timeoutMs:Zi})}n(Vi,"defaultIdpFetchJson");function Rl(e){return(t,r)=>ci(t,r,{context:e,maxRedirects:Wi,maxResponseBytes:Ki,problemCode:"upstream_token_exchange_failed",timeoutMs:Zi})}n(Rl,"defaultResourceAsFetchJson");function lr(e){let t={[g]:e.code,[we]:e.tokenUrl};return e.response!==void 0&&(t[_e]=e.response.status),new h({message:e.message,extensionMembers:t},e.cause===void 0?void 0:{cause:e.cause})}n(lr,"runtimeError");function an(e){if(!e.response.ok)throw lr({code:"upstream_token_exchange_failed",message:(()=>{switch(e.stage){case"idp_refresh_token":return"IdP refresh-token grant failed while renewing the upstream ID-JAG subject token.";case"idp_token_exchange":return"IdP token exchange failed while requesting an upstream ID-JAG.";case"resource_as_jwt_bearer":return"Upstream Resource AS rejected the ID-JAG JWT-bearer exchange."}})(),tokenUrl:e.tokenUrl,response:e.response})}n(an,"assertTokenEndpointSucceeded");function bl(e){let t=hl.safeParse(e.json);if(!t.success)throw lr({code:"upstream_token_response_invalid",message:"IdP refresh-token grant returned an invalid subject-token response.",tokenUrl:e.tokenUrl,response:e.response,cause:t.error});let r={idToken:t.data.id_token};return t.data.expires_in!==void 0&&(r.expiresIn=t.data.expires_in),t.data.refresh_token!==void 0&&(r.refreshToken=t.data.refresh_token),t.data.scope!==void 0&&(r.scope=t.data.scope),r}n(bl,"parseIdpRefreshTokenResponse");function Il(e){let t=fl.safeParse(e.json);if(!t.success)throw lr({code:"upstream_token_response_invalid",message:"IdP token exchange returned an invalid ID-JAG response.",tokenUrl:e.tokenUrl,response:e.response,cause:t.error});let r={assertion:t.data.access_token};return t.data.expires_in!==void 0&&(r.expiresIn=t.data.expires_in),t.data.scope!==void 0&&(r.scope=t.data.scope),r}n(Il,"parseIdJagTokenExchangeResponse");function Sl(e){let t=gl.safeParse(e.json);if(!t.success)throw lr({code:"upstream_token_response_invalid",message:"Upstream Resource AS returned an invalid JWT-bearer token response.",tokenUrl:e.tokenUrl,response:e.response,cause:t.error});let r={accessToken:t.data.access_token,tokenType:t.data.token_type};return t.data.expires_in!==void 0&&(r.expiresIn=t.data.expires_in),t.data.scope!==void 0&&(r.scope=t.data.scope),t.data.resource!==void 0&&(r.resource=t.data.resource),t.data.refresh_token!==void 0&&(r.refreshToken=t.data.refresh_token),r}n(Sl,"parseAccessTokenResponse");async function Yi(e){let t=new URLSearchParams({grant_type:$t,requested_token_type:xr,subject_token:e.subjectToken,subject_token_type:e.subjectTokenType,audience:e.audience});e.resource!==void 0&&t.set("resource",e.resource),e.scope!==void 0&&t.set("scope",e.scope),e.authorizationDetails!==void 0&&t.set("authorization_details",JSON.stringify(e.authorizationDetails));let r=e.fetchJson??Vi(e.context),{response:o,json:i}=await r(e.idp.tokenUrl,await on({form:t,clientAuth:e.clientAuth,tokenUrl:e.idp.tokenUrl}));return an({response:o,tokenUrl:e.idp.tokenUrl,stage:"idp_token_exchange"}),Il({json:i,response:o,tokenUrl:e.idp.tokenUrl})}n(Yi,"requestIdJag");async function Xi(e){let t=new URLSearchParams({grant_type:"refresh_token",refresh_token:e.refreshToken}),r=e.fetchJson??Vi(e.context),{response:o,json:i}=await r(e.idp.tokenUrl,await on({form:t,clientAuth:e.clientAuth,tokenUrl:e.idp.tokenUrl}));return an({response:o,tokenUrl:e.idp.tokenUrl,stage:"idp_refresh_token"}),bl({json:i,response:o,tokenUrl:e.idp.tokenUrl})}n(Xi,"refreshIdpSubjectToken");async function Qi(e){let t=new URLSearchParams({grant_type:be,assertion:e.assertion});e.resource!==void 0&&t.set("resource",e.resource),e.scope!==void 0&&t.set("scope",e.scope);let r=e.fetchJson??Rl(e.context),{response:o,json:i}=await r(e.resourceAs.tokenUrl,await on({form:t,clientAuth:e.clientAuth,tokenUrl:e.resourceAs.tokenUrl}));return an({response:o,tokenUrl:e.resourceAs.tokenUrl,stage:"resource_as_jwt_bearer"}),Sl({json:i,response:o,tokenUrl:e.resourceAs.tokenUrl})}n(Qi,"exchangeIdJagForAccessToken");function Cl(e){return Tt(e)==="usable"}n(Cl,"hasUsableAccessToken");function vl(e){if(e.tokenType.toLowerCase()!=="bearer")throw new h({message:"Upstream Resource AS returned a token type the MCP gateway cannot send as a bearer token.",extensionMembers:{[g]:"upstream_token_response_invalid"}})}n(vl,"assertBearerToken");function ea(e,t){if(t===Fe)return!1;let r=e?.metadata?.idpSubjectTokenExpiresAt;return r!==void 0&&new Date(r).getTime()<=Date.now()}n(ea,"hasExpiredSubjectToken");async function Al(e){let t=await ve(e.encryptedSubjectToken);if(e.subjectTokenType!==Fe)return{connection:e.connection,subjectToken:t,subjectTokenType:e.subjectTokenType};let r=await Xi({idp:e.idp,refreshToken:t,clientAuth:e.clientAuth,context:e.context});if(r.refreshToken===void 0)return{connection:e.connection,subjectToken:r.idToken,subjectTokenType:ut};let o=await b().upsertUpstreamConnection({id:e.connection.id,ownerMode:e.connection.ownerMode,subjectId:e.connection.subjectId,upstreamServerId:e.connection.upstreamServerId,authProfileId:e.connection.authProfileId,status:"active",encryptedAccessToken:e.connection.encryptedAccessToken,encryptedRefreshToken:e.connection.encryptedRefreshToken,scopes:e.connection.scopes,expiresAt:e.connection.expiresAt,metadata:{...e.connection.metadata??{},encryptedIdpSubjectToken:await me(r.refreshToken),idpSubjectTokenType:Fe,idpSubjectTokenExpiresAt:void 0}});return J()?.info({event:"upstream_id_jag_subject_token_rotated",upstreamServerId:e.connection.upstreamServerId,authProfileId:e.connection.authProfileId,connectionFingerprint:e.connectionFingerprint,connectionId:o.id,priorStatus:e.connection.status,priorUpdatedAt:e.connection.updatedAt,usedSubjectRefreshTokenFingerprint:await We(t),newSubjectRefreshTokenFingerprint:await We(r.refreshToken)},"Upstream ID-JAG IdP subject refresh token rotated and persisted"),{connection:o,subjectToken:r.idToken,subjectTokenType:ut}}n(Al,"resolveIdJagSubjectToken");async function ta(e){let t="preloadedConnection"in e?e.preloadedConnection:(await b().batchGetUpstreamConnections([{owner:e.owner,upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId}]))[0],r=Tt(t),o=!!e.forceRefresh,i=!o&&r==="usable",a=J(),c=a?await Ve({owner:e.owner,upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId}):void 0;if(a?.debug({event:"upstream_id_jag_auth_decision",upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,ownerMode:e.owner.mode,connectionFingerprint:c,connectionId:t?.id,accessTokenState:r,forceRefresh:o,willMint:!i,expiresAt:t?.expiresAt,connectionUpdatedAt:t?.updatedAt},i?"Reusing stored upstream ID-JAG access token":"Minting upstream ID-JAG access token"),!e.forceRefresh&&Cl(t))return{kind:"authorized",credential:{type:"bearer_token",token:await ve(t.encryptedAccessToken)}};let s=t?.metadata?.encryptedIdpSubjectToken,u=t?.metadata?.idpSubjectTokenType;if(t?.status!=="active"||s===void 0||u===void 0||ea(t,u))return a?.debug({event:"upstream_id_jag_connect_required",upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,connectionFingerprint:c,connectionId:t?.id,status:t?.status??"not_connected",hasSubjectToken:s!==void 0,subjectTokenType:u,subjectTokenExpired:u!==void 0&&ea(t,u)},"Upstream ID-JAG requires an admin subject-token binding"),{kind:"connect_required",payload:{state:"admin_connect_required",upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,operationId:e.operationId,message:`An IdP subject-token binding is required for ${e.upstreamDisplayName} before this tool can use XAA / ID-JAG.`,nextAction:"admin_setup_required"}};let p=Ie(e.upstreamServerId),f=oi(e.upstreamServerId,e.authProfileId),w=f.resourceAs.resource??p.transport.baseUrl,U=e.requestedScope??(f.scopes.length===0?void 0:f.scopes.join(f.scopeDelimiter)),y=await Al({connection:t,connectionFingerprint:c,encryptedSubjectToken:s,subjectTokenType:u,idp:{tokenUrl:f.idp.tokenUrl},clientAuth:f.idp.clientAuth,context:e.context}),P=await Yi({idp:{tokenUrl:f.idp.tokenUrl},subjectToken:y.subjectToken,subjectTokenType:y.subjectTokenType,audience:f.resourceAs.audience,resource:w,scope:U,clientAuth:f.idp.clientAuth,context:e.context}),x=P.scope??U,z=await Qi({resourceAs:{tokenUrl:f.resourceAs.tokenUrl},assertion:P.assertion,resource:w,scope:x,clientAuth:f.resourceAs.clientAuth,context:e.context});if(vl(z),t!==void 0){let X=(z.scope??x)?.split(/[,\s]+/).filter(Boolean)??[],E=z.expiresIn===void 0?void 0:I(new Date(Date.now()+z.expiresIn*1e3)),D=await b().upsertUpstreamConnection({id:y.connection.id,ownerMode:y.connection.ownerMode,subjectId:y.connection.subjectId,upstreamServerId:y.connection.upstreamServerId,authProfileId:y.connection.authProfileId,status:"active",encryptedAccessToken:await me(z.accessToken),encryptedRefreshToken:y.connection.encryptedRefreshToken,scopes:X,expiresAt:E,metadata:y.connection.metadata});a?.info({event:"upstream_id_jag_access_token_persisted",upstreamServerId:e.upstreamServerId,authProfileId:e.authProfileId,connectionFingerprint:c,connectionId:D.id,priorStatus:y.connection.status,priorUpdatedAt:y.connection.updatedAt,scopeCount:X.length,expiresAt:E},"Upstream ID-JAG access token persisted; connection is active")}return{kind:"authorized",credential:{type:"bearer_token",token:z.accessToken}}}n(ta,"authorizeUpstreamIdJagRequest");function xl(e){return ur(new URL(e.callbackPath,q(e.requestUrl,e.requestHeaders))).toString()}n(xl,"buildGatewayOAuthRedirectUri");async function ra(e){let t=Ie(e.upstreamServerId),r=Ze(e.upstreamServerId,e.authProfileId),o=xl({callbackPath:r.redirectPath,requestUrl:e.request.url,requestHeaders: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,returnTo:e.returnTo},redirectUri:o,returnOrigin:q(e.request.url,e.request.headers)}}}n(ra,"prepareUpstreamOAuthRequest");async function na(e){let t=await ra(e),r=new qe({...t.providerInput,...t.connection?.metadata===void 0?{}:{connectionMetadata:t.connection.metadata}});return Ji(r,{upstreamServerId:e.upstreamServerId,serverUrl:t.upstreamServerConfig.transport.baseUrl,resourceMetadataUrl:t.upstreamServerConfig.transport.resourceMetadataUrl})}n(na,"startUpstreamConnect");async function oa(e){let t=await ra(e),r=new qe({...t.providerInput,...t.connection===void 0?{}:{connection:t.connection}});return Gi({target:e,provider:r,connection:t.connection,forceRefresh:e.forceRefresh,requestedScope:e.requestedScope,upstreamDisplayName:t.upstreamServerConfig.displayName,serverUrl:t.upstreamServerConfig.transport.baseUrl,resourceMetadataUrl:t.upstreamServerConfig.transport.resourceMetadataUrl})}n(oa,"authorizeUpstreamRequest");async function Xe(e){let{routeAuth:t}=e;switch(t.authMode){case"shared-oauth":case"user-oauth":return oa({request:e.request,owner:t.owner,initiatedBySubjectId:t.initiatedBySubjectId,upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId,operationId:t.operationId,forceRefresh:e.forceRefresh,requestedScope:e.requestedScope,...e.preloadedConnection===void 0?{}:{preloadedConnection:e.preloadedConnection},returnTo:t.returnTo});case"id-jag":return ta({request:e.request,context:e.context,authMode:t.authMode,ownerMode:t.ownerMode,owner:t.owner,initiatedBySubjectId:t.initiatedBySubjectId,upstreamServerId:t.upstreamServerId,authProfileId:t.authProfileId,operationId:t.operationId,upstreamDisplayName:t.upstreamDisplayName,forceRefresh:e.forceRefresh,requestedScope:e.requestedScope,...e.preloadedConnection===void 0?{}:{preloadedConnection:e.preloadedConnection},returnTo:t.returnTo})}let r=t;throw new Q(`Unsupported upstream auth route context ${JSON.stringify(r)}.`)}n(Xe,"resolveUpstreamCredentialForRoute");async function ia(e){if(e.connectRequest.authMode==="id-jag")throw new Q(`Upstream server ${e.connectRequest.upstreamServerId} uses XAA / ID-JAG and does not support browser OAuth connection flows.`);let t=await na({request:e.request,owner:e.connectRequest.owner,initiatedBySubjectId:e.connectRequest.initiatedBySubjectId,upstreamServerId:e.connectRequest.upstreamServerId,authProfileId:e.connectRequest.authProfileId,operationId:e.connectRequest.operationId,returnTo:e.connectRequest.returnTo});return{authProfileId:e.connectRequest.authProfileId,authUrl:t,initiatedBySubjectId:e.connectRequest.initiatedBySubjectId,owner:e.connectRequest.owner,upstreamDisplayName:e.connectRequest.upstreamDisplayName,operationId:e.connectRequest.operationId}}n(ia,"startUpstreamConnectForRequest");async function aa(e){let r=(await cr(e.callbackRequest.state)).authProfileId;if(ir({upstreamServerId:e.callbackRequest.upstreamServerId,authProfileId:r}).mode==="id-jag")throw new Q(`Upstream server ${e.callbackRequest.upstreamServerId} uses XAA / ID-JAG and does not support OAuth callbacks.`);return Fi({request:e.request,upstreamServerId:e.callbackRequest.upstreamServerId,authorizationCode:e.callbackRequest.code,stateToken:e.callbackRequest.state,upstreamServerConfig:Ie(e.callbackRequest.upstreamServerId)})}n(aa,"finishUpstreamCallbackForRequest");function kl(e){return{upstreamServerId:e.connection.upstreamServerId,operationId:e.operationId,authProfileId:e.connection.authProfileId,upstreamDisplayName:e.connection.displayName,authMode:e.connection.authMode,ownerMode:e.connection.ownerMode}}n(kl,"buildRouteAuthBaseFromConnection");function sa(e){return{upstreamServerId:e.connection.id,operationId:e.operationId,authProfileId:mo(e.connection.id,e.connection.authMode),upstreamDisplayName:e.connection.displayName,authMode:e.connection.authMode,ownerMode:e.connection.ownerMode}}n(sa,"buildRouteAuthBaseFromPolicyOptions");function pr(e,t){let o=ee().byOperationId.get(t);if(!o)throw new B(`Unknown MCP route "${t}". Ensure routes.oas.json declares this operationId before starting an upstream connection flow.`);if(o.connection===void 0)throw new B(`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 B(`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 kl({connection:o.connection,operationId:t})}n(pr,"resolveRouteAuthBase");function sn(e,t){switch(e){case"user":return Je(t);case"shared":return lo()}}n(sn,"buildOwnerForSubject");function Qe(e,t){switch(e.authMode){case"shared-oauth":return{...e,authMode:"shared-oauth",ownerMode:"shared",owner:sn("shared",t),initiatedBySubjectId:t};case"user-oauth":return{...e,authMode:"user-oauth",ownerMode:"user",owner:sn("user",t),initiatedBySubjectId:t};case"id-jag":return{...e,authMode:"id-jag",ownerMode:"user",owner:sn("user",t),initiatedBySubjectId:t}}}n(Qe,"resolveRouteAuthForSubject");var Tl=st.InvalidRequest,Ul=new Set(["connection","keep-alive","proxy-authenticate","te","trailer","transfer-encoding","upgrade"]);function Pl(e,t){return{credentialType:e.type,forceRefresh:t}}n(Pl,"buildCredentialResolvedAttributes");function El(e){switch(e){case"admin_connect_required":return"admin_connect_required";case"authenticating":return"connect_required"}}n(El,"connectRequiredReasonCode");function ca(e){v(e.context,{eventType:S.MCP_AUTH_UPSTREAM_CREDENTIAL_RESOLVED,outcome:"success",routeBinding:e.routeBinding,attributes:Pl(e.credential,e.forceRefresh===!0)})}n(ca,"emitCredentialResolvedAnalyticsEvent");function da(e){let t={forceRefresh:e.forceRefresh===!0,nextAction:e.payload.nextAction,state:e.payload.state};if(v(e.context,{eventType:S.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:S.MCP_AUTH_UPSTREAM_RECONSENT_REQUIRED,outcome:"connect_required",routeBinding:e.routeBinding,reasonCode:"reconsent_required",reasonClass:"auth",attributes:t});return}v(e.context,{eventType:S.MCP_AUTH_UPSTREAM_CONNECT_REQUIRED,outcome:"connect_required",routeBinding:e.routeBinding,reasonCode:El(e.payload.state),reasonClass:"auth",attributes:t})}n(da,"emitCredentialMissingAnalyticsEvents");function Ol(e){let t=e.route.raw();return Nt.parse(t?.operationId)}n(Ol,"readOperationId");async function ql(e,t,r,o){let i=await Xe({request:e,context:o,routeAuth:t});if(i.kind==="connect_required")return da({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;if(ca({context:o,credential:a,routeBinding:t}),a.type==="bearer_token")return{kind:"headers",headers:[["authorization",`Bearer ${a.token}`]]};let c=await a.provider.tokens();return c?{kind:"headers",headers:[["authorization",`${c.token_type??"Bearer"} ${c.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(ql,"buildCredentialHeaders");var Ml=new Set(["authorization","cookie","cookie2"]);function Dl(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(Dl,"readJsonRequestMethod");function jl(e){let t=e.headers.get("content-type")??"";return/\bapplication\/(?:[\w.+-]+\+)?json\b/i.test(t)}n(jl,"isJsonResponse");function cn(e){return e!==null&&typeof e=="object"&&!Array.isArray(e)}n(cn,"isRecord");function zl(e){return Array.isArray(e)&&e.length>0}n(zl,"hasIconList");function Hl(e){if(e.connection.serverInfo?.icons!==void 0&&e.connection.serverInfo.icons.length>0)return e.connection.serverInfo.icons;try{let t=or(no(e.context.route.handler));return t===void 0?void 0:[t]}catch{return}}n(Hl,"readFallbackServerIcons");function Bl(e){if(!cn(e.body))return e.body;let t=e.body.result;if(!cn(t))return e.body;let r=t.serverInfo;return!cn(r)||zl(r.icons)?e.body:{...e.body,result:{...t,serverInfo:{...r,icons:e.icons}}}}n(Bl,"addMissingServerIcons");function Ll(e,t){let r=new Headers(e.headers);for(let o of Ml)r.delete(o);for(let[o,i]of t)r.set(o,i);return new Ln(e,{headers:r})}n(Ll,"applyUpstreamHeaders");function Nl(e){let t=new Headers(e.headers);for(let r of Ul)t.delete(r);return t}n(Nl,"buildProxyHeaders");async function Jl(e){if(!(e.method==="GET"||e.method==="HEAD"))return e.clone().arrayBuffer()}n(Jl,"readRetryBody");function ua(e,t){let r=t.authUrl===void 0?void 0:Lo({message:t.message,elicitationId:["connect",t.operationId,t.upstreamServerId,t.authProfileId].join(":"),url:t.authUrl});return Response.json(Xt({id:Bo(e),error:{code:r?.code??Tl,message:t.message,data:{...r?.data??{},connectRequired:t}}}))}n(ua,"connectRequiredJsonRpcResponse");async function Gl(e){let{scope:t}=Qo(e.upstreamResponse),r=await Xe({request:e.request,context:e.context,routeAuth:e.routeAuth,forceRefresh:!0,requestedScope:t});if(r.kind==="connect_required")return da({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;if(ca({context:e.context,credential:i,routeBinding:e.routeAuth,forceRefresh:!0}),i.type==="bearer_token")return o.set("authorization",`Bearer ${i.token}`),{kind:"headers",headers:o};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(Gl,"applyRefreshedCredentialHeaders");function Fl(e){e.context.addResponseSendingHook(async(t,r)=>{if(t.status!==401)return t;let o=await Gl({request:e.request,context:e.context,headers:Nl(r),routeAuth:e.routeAuth,upstreamResponse:t});if(o.kind==="connect_required")return ua(e.requestBody,o.payload);if(o.kind==="response")return o.response;let i=oo({handler:e.context.route.handler,request:r,body:e.requestBody,headers:o.headers});return jt.fetch(i.url,i.init)})}n(Fl,"installUpstreamAuthRetryHook");function $l(e){if(Dl(e.requestBody)!=="initialize")return;let t=Hl({connection:e.connection,context:e.context});t===void 0||t.length===0||e.context.addResponseSendingHook(async r=>{if(!jl(r))return r;let o;try{o=await r.clone().json()}catch{return r}let i=Bl({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($l,"installInitializeIconHook");async function dn(e,t,r){let o=Ol(t),i=await Jl(e),a=sa({connection:r,operationId:o}),c=Te(e.user,e.url,e.headers);t.log.setLogProperties?.({requestId:t.requestId}),wo(t,c);let s=Qe(a,c.subjectId),u=await ql(e,s,r,t);if(!(u instanceof Response)&&u.kind==="connect_required")return ua(i,u.payload);if(u instanceof Response)return u;let p=Ll(e,u.headers);return Fl({request:p,context:t,requestBody:i,routeAuth:s}),$l({context:t,requestBody:i,connection:r}),p}n(dn,"mcpTokenExchangePolicy");var un=class extends zt{static{n(this,"McpTokenExchangeInboundPolicy")}static policyType="mcp-token-exchange";constructor(t,r){let o=fo(t,r);super(o,r)}async handler(t,r){return dn(t,r,this.options)}};Z();var la=Symbol("Html");function Zl(e){return e.replaceAll("&","&amp;").replaceAll("<","&lt;").replaceAll(">","&gt;").replaceAll('"',"&quot;").replaceAll("'","&#39;")}n(Zl,"escapeHtml");function Kl(e){return e===null||typeof e!="object"?!1:e[la]===!0}n(Kl,"isHtml");function pa(e){return e==null||e===!1?"":Array.isArray(e)?e.map(pa).join(""):Kl(e)?e.value:Zl(String(e))}n(pa,"renderValue");function fe(e){return{[la]:!0,value:e}}n(fe,"trustedHtml");var te=fe("");function C(e,...t){let r=e[0]??"";for(let o=0;o<t.length;o+=1)r+=pa(t[o]),r+=e[o+1]??"";return fe(r)}n(C,"html");function et(e){return e.value}n(et,"renderHtml");function ma(e){return C`<p class="card__description">${e.detail}</p>${e.guidance} ${e.technicalDetails} ${e.action}`}n(ma,"renderBrowserErrorPage");var tt=fe('*,: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 rt(e){return C`<!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>
27
27
  ${e.styles}
28
- </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(rt,"renderShell");var Wl="text/html; charset=utf-8";function nt(e){try{return new URL(e).host}catch{return""}}n(nt,"safeHostFromUrl");function ae(e){let t=Yl(e.kind??"authorization_failed"),r=Vl(e);return new Response(et(rt({title:e.title??t.title,iconHref:"",styles:tt,headerIcon:re,heading:e.title??t.title,subhead:"",body:ma({detail:e.detail,guidance:C`<p class="card__description">${t.guidance}</p>`,technicalDetails:rp({diagnostic:r,upstreamHtml:e.upstreamHtml}),action:ep(e.action)}),footer:""})),{status:e.status??400,headers:{"content-type":Wl,"cache-control":"no-store","referrer-policy":"no-referrer","x-frame-options":"DENY"}})}n(ae,"browserErrorPageResponse");function Vl(e){let t=e.diagnostic?.code??e.code??"unknown";return{code:t,stage:e.diagnostic?.stage??Xl(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??Ql(t),underlyingError:e.diagnostic?.underlyingError??e.developerDetail}}n(Vl,"buildBrowserErrorDiagnostic");function Yl(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(Yl,"readBrowserErrorPagePresentation");function Xl(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(Xl,"readBrowserErrorStage");function Ql(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(Ql,"readBrowserErrorSuggestedFix");function ep(e){return e===void 0?re:C`<a class="button button--primary button--block" href="${e.href}">${e.label}</a>`}n(ep,"renderAction");function tp(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(`
29
- `);return C`<pre class="banner__message" style="white-space: pre-wrap; overflow-wrap: anywhere; margin-top: 8px;"><code>${t}</code></pre>`}n(tp,"renderTechnicalPre");function mr(e){return e.value===void 0||e.value===""?re:C`<p class="banner__message"><strong>${e.label}:</strong> <code>${e.value}</code></p>`}n(mr,"renderOptionalTechnicalRow");function rp(e){return C`<section class="banner banner--warning" aria-label="Developer details">
28
+ </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(rt,"renderShell");var Wl="text/html; charset=utf-8";function nt(e){try{return new URL(e).host}catch{return""}}n(nt,"safeHostFromUrl");function ie(e){let t=Yl(e.kind??"authorization_failed"),r=Vl(e);return new Response(et(rt({title:e.title??t.title,iconHref:"",styles:tt,headerIcon:te,heading:e.title??t.title,subhead:"",body:ma({detail:e.detail,guidance:C`<p class="card__description">${t.guidance}</p>`,technicalDetails:rp({diagnostic:r,upstreamHtml:e.upstreamHtml}),action:ep(e.action)}),footer:""})),{status:e.status??400,headers:{"content-type":Wl,"cache-control":"no-store","referrer-policy":"no-referrer","x-frame-options":"DENY"}})}n(ie,"browserErrorPageResponse");function Vl(e){let t=e.diagnostic?.code??e.code??"unknown";return{code:t,stage:e.diagnostic?.stage??Xl(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??Ql(t),underlyingError:e.diagnostic?.underlyingError??e.developerDetail}}n(Vl,"buildBrowserErrorDiagnostic");function Yl(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(Yl,"readBrowserErrorPagePresentation");function Xl(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(Xl,"readBrowserErrorStage");function Ql(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(Ql,"readBrowserErrorSuggestedFix");function ep(e){return e===void 0?te:C`<a class="button button--primary button--block" href="${e.href}">${e.label}</a>`}n(ep,"renderAction");function tp(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(`
29
+ `);return C`<pre class="banner__message" style="white-space: pre-wrap; overflow-wrap: anywhere; margin-top: 8px;"><code>${t}</code></pre>`}n(tp,"renderTechnicalPre");function mr(e){return e.value===void 0||e.value===""?te:C`<p class="banner__message"><strong>${e.label}:</strong> <code>${e.value}</code></p>`}n(mr,"renderOptionalTechnicalRow");function rp(e){return C`<section class="banner banner--warning" aria-label="Developer details">
30
30
  <span class="banner__icon" aria-hidden="true">!</span>
31
31
  <div class="banner__body">
32
32
  <p class="banner__title">Developer details</p>
@@ -40,11 +40,11 @@ import{$b as Ac,$c as Co,Ab as q,Ac as yo,Ad as x,Bb as Qn,Bc as _o,Bd as Yt,Cb
40
40
  ${tp(e.diagnostic)}
41
41
  ${np(e.upstreamHtml)}
42
42
  </div>
43
- </section>`}n(rp,"renderTechnicalDetails");function np(e){return e===void 0?re:C`<iframe
43
+ </section>`}n(rp,"renderTechnicalDetails");function np(e){return e===void 0?te:C`<iframe
44
44
  title="Upstream HTML error response"
45
45
  sandbox
46
46
  srcdoc="${e}"
47
47
  style="border: 1px solid var(--warning-border); border-radius: var(--radius-sm); background: white; width: 100%; min-height: 220px; margin-top: 8px;"
48
- ></iframe>`}n(np,"renderUpstreamHtml");var fa="application/json",op="application/x-www-form-urlencoded";function fr(e,t){return new h({message:e,extensionMembers:{[g]:"invalid_request"}},t===void 0?void 0:{cause:t})}n(fr,"invalidRequestError");function ip(e){return(e??"").split(";")[0]?.trim().toLowerCase()??""}n(ip,"normalizeContentType");function ap(e,t){return e===t?!0:t===fa&&e.endsWith("+json")}n(ap,"contentTypeMatches");function sp(e,t){if(!t||t.length===0)return;let r=ip(e.headers.get("content-type"));if(!t.some(o=>ap(r,o)))throw fr(`Request body must be ${t.join(" or ")}.`)}n(sp,"assertExpectedContentType");function cp(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 fr(`${r} exceeded the maximum allowed size.`)}n(cp,"assertContentLengthWithinLimit");async function ha(e,t){let r=t.label??"Request body";sp(e,t.expectedContentTypes),cp(e,t.maxBytes,r);let o=await ar(e.body,{maxBytes:t.maxBytes,createLimitError:n(()=>fr(`${r} exceeded the maximum allowed size.`),"createLimitError")});return new TextDecoder().decode(o)}n(ha,"readBoundedTextBody");async function ga(e,t){let r=await ha(e,{...t,expectedContentTypes:[fa]});try{return JSON.parse(r)}catch(o){throw fr("Request body must be valid JSON.",o)}}n(ga,"readBoundedJsonBody");async function ya(e,t){let r=await ha(e,{...t,expectedContentTypes:[op]});return new URLSearchParams(r)}n(ya,"readBoundedFormUrlEncodedBody");K();K();import{errors as wa,jwtVerify as Ra,SignJWT as ba}from"jose";import{base64url as dp}from"jose";var up="mcp-browser-login-pkce:",lp=new TextEncoder;async function pp(e){return crypto.subtle.importKey("raw",G(e),{name:"HMAC",hash:"SHA-256"},!1,["sign"])}n(pp,"importHmacKey");async function ln(e){let t=await pp(e.signingKey),r=lp.encode(`${up}${e.stateId}`),o=await crypto.subtle.sign("HMAC",t,G(r));return Be.parse(dp.encode(new Uint8Array(o)))}n(ln,"deriveBrowserLoginPkceVerifier");async function _a(e){let t=await ln(e),r=await Yt(t);return{codeVerifier:t,codeChallenge:r,codeChallengeMethod:He}}n(_a,"deriveBrowserLoginPkceParams");var mp={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},m=class extends Error{static{n(this,"OAuthProtocolError")}errorCode;status;constructor(t,r,o=mp[t],i){super(r,i),this.name="OAuthProtocolError",this.errorCode=t,this.status=o}};var fp=300,hp=d.object({purpose:d.literal("gateway_browser_login"),transactionId:xr,stateId:Tr,exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),gp=d.object({purpose:d.literal("gateway_authorization_setup"),transactionId:xr,stateId:Tr,exp:d.number().int().positive(),iat:d.number().int().positive().optional()});async function Ut(){return ie({purpose:"browser-login",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>Se(e,"browser-login"),"derive")})}n(Ut,"getBrowserLoginKey");async function Ia(){return ie({purpose:"authorization-csrf",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>Se(e,"authorization-csrf"),"derive")})}n(Ia,"getCsrfKey");function Sa(e){return{now:e.now??new Date,ttlSeconds:Ca()}}n(Sa,"readPendingTransactionDependencies");function Ca(){return L().browserLogin.stateTtlSeconds}n(Ca,"readBrowserLoginStateTtlSeconds");function yp(e){let t=H();return W(e)&&t.isActionPath(e.pathname,"/oauth/dev-login")}n(yp,"isLoopbackDevLoginUrl");async function _p(e){let t=L().browserLogin,r=H(),o=new URL(Re("url")),i=new URL(r.actionPath("/oauth/callback"),Ge(e.requestUrl,e.requestHeaders));if(yp(o))return o.searchParams.set("redirect_uri",i.toString()),o.searchParams.set("state",e.state),o;if(o.searchParams.set("response_type","code"),o.searchParams.set("client_id",Re("clientId")),o.searchParams.set("redirect_uri",i.toString()),o.searchParams.set("scope",t.scope),o.searchParams.set("state",e.state),o.searchParams.set("nonce",e.nonce),t.audience&&o.searchParams.set("audience",t.audience),t.pkce===He){let a=await _a({stateId:e.stateId,signingKey:await Ut()});o.searchParams.set("code_challenge",a.codeChallenge),o.searchParams.set("code_challenge_method",a.codeChallengeMethod)}return o}n(_p,"buildBrowserLoginUrl");function wp(e,t){return e.subjectId===t.subjectId}n(wp,"principalsMatch");function va(e){return{subjectId:e.subjectId,...e.roles===void 0?{}:{roles:e.roles}}}n(va,"toPendingPrincipal");function Aa(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:I(e.now),expiresAt:I(de(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 R("identity_context_missing","Authorization setup requires a principal.");return{...t,phase:"awaiting_setup",principal:va(e.principal)}}n(Aa,"createTransactionRecord");async function ka(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 R("oauth_state_reused","Authorization transaction state already exists.");case"invalid_client":throw new m("invalid_client","OAuth client is not registered.");case"redirect_uri_mismatch":throw new m("invalid_request","redirect_uri is not registered for the client.")}}n(ka,"startPendingTransaction");async function Rp(e){return new ba({purpose:"gateway_browser_login",transactionId:e.transactionId,stateId:e.stateId}).setProtectedHeader({alg:Y,typ:"JWT"}).setIssuer($).setAudience(V).setIssuedAt().setExpirationTime(Math.floor(Date.now()/1e3)+e.ttlSeconds).sign(await Ut())}n(Rp,"signBrowserLoginState");async function xa(e){return new ba({purpose:"gateway_authorization_setup",transactionId:e.transactionId,stateId:Pr()}).setProtectedHeader({alg:Y,typ:"JWT"}).setIssuer($).setAudience(V).setIssuedAt().setExpirationTime(Math.floor(Date.now()/1e3)+e.ttlSeconds).sign(await Ia())}n(xa,"signCsrfToken");async function pn(e){try{let{payload:t}=await Ra(e,await Ut(),{algorithms:[Y],issuer:$,audience:V}),r=hp.parse(t);return{transactionId:r.transactionId,stateId:r.stateId}}catch(t){throw t instanceof wa.JWTExpired?R("oauth_state_expired","Browser login state has expired.",t):R("oauth_state_invalid","Browser login state could not be verified.",t)}}n(pn,"verifyBrowserLoginStateToken");async function hr(e){try{let{payload:t}=await Ra(e,await Ia(),{algorithms:[Y],issuer:$,audience:V});return{transactionId:gp.parse(t).transactionId}}catch(t){throw t instanceof wa.JWTExpired?R("oauth_state_expired","Authorization setup state has expired.",t):R("oauth_state_invalid","Authorization setup state could not be verified.",t)}}n(hr,"verifyCsrfToken");function mn(e){return e==="consumed"||e==="consumed_already"||e==="stale_hash"?"oauth_state_reused":e==="expired"?"oauth_state_expired":"oauth_state_invalid"}n(mn,"pendingStateErrorCode");function bp(e){return e.kind==="available"?{kind:"available",record:e.transaction}:e}n(bp,"toPendingAuthorizationGetResult");function Ip(e){return e.kind==="advanced"?{kind:"advanced",record:e.transaction}:e}n(Ip,"toPendingAuthorizationAdvanceResult");function fn(e){return e==="principal_mismatch"?"oauth_callback_mismatch":mn(e==="consumed_already"?"consumed_already":e)}n(fn,"setupDecisionErrorCode");async function Ta(e){let t=e.now??new Date,r=await hr(e.csrfToken),o=await b().markAuthorizationSetupApproved({transactionId:r.transactionId,currentStateHash:await x(e.csrfToken),currentPrincipal:{subjectId:e.currentBrowserPrincipal.subjectId},now:I(t)});if(o.kind!=="marked")throw R(fn(o.kind),"Authorization setup state is invalid, expired, or already used.");return Ua({kind:"available",record:o.transaction})}n(Ta,"markSetupApproved");function Ua(e){if(e.kind!=="available")throw R(mn(e.kind),"Authorization setup state is invalid, expired, or already used.");if(e.record.phase!=="awaiting_setup")throw R("oauth_state_invalid","Authorization setup state is not in the setup phase.");return e.record}n(Ua,"requireAwaitingSetup");function Sp(e){if(!wp(e.currentBrowserPrincipal,e.transaction.principal))throw R("oauth_callback_mismatch","Authorization setup state does not match the current browser session.")}n(Sp,"requireCurrentPrincipalMatches");async function Pa(e){let t=e.now??new Date,r=Ca(),o=Ur(),i=Pr(),a=await Rp({transactionId:o,stateId:i,ttlSeconds:r}),c=Aa({id:o,transaction:e.transaction,currentStateHash:await x(a),phase:"awaiting_login",now:t,ttlSeconds:r});if(c.phase!=="awaiting_login")throw R("oauth_state_invalid","Authorization transaction did not start in login phase.");let s=await ka({record:c,client:e.transaction.client});if(s.phase!=="awaiting_login")throw R("oauth_state_invalid","Authorization transaction did not start in login phase.");let u=await _p({state:a,nonce:i,stateId:i,requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders}});return{transaction:s,browserLoginStateToken:a,browserLoginUrl:u}}n(Pa,"startAwaitingLogin");async function Ea(e){let{now:t,ttlSeconds:r}=Sa(e),o=Ur(),i=await xa({transactionId:o,ttlSeconds:r}),a=Aa({id:o,transaction:e.transaction,currentStateHash:await x(i),phase:"awaiting_setup",principal:e.principal,now:t,ttlSeconds:r});if(a.phase!=="awaiting_setup")throw R("oauth_state_invalid","Authorization transaction did not start in setup phase.");let c=await ka({record:a,client:e.transaction.client});if(c.phase!=="awaiting_setup")throw R("oauth_state_invalid","Authorization transaction did not start in setup phase.");return{transaction:c,csrfToken:i}}n(Ea,"startAwaitingSetup");async function Oa(e){let{now:t,ttlSeconds:r}=Sa(e),o=await pn(e.browserLoginStateToken),i=await xa({transactionId:o.transactionId,ttlSeconds:r}),a=Ip(await b().advancePendingAuthorization({transactionId:o.transactionId,expectedPhase:"awaiting_login",currentStateHash:await x(e.browserLoginStateToken),nextStateHash:await x(i),nextPhase:"awaiting_setup",principal:va(e.principal),now:I(t)}));if(a.kind!=="advanced")throw R(mn(a.kind),"Browser login state is invalid, expired, or already used.");if(a.record.phase!=="awaiting_setup")throw R("oauth_state_invalid","Browser login did not advance to setup.");return{transaction:a.record,csrfToken:i}}n(Oa,"completeLogin");async function qa(e){let t=await hn(e);return Sp({transaction:t,currentBrowserPrincipal:e.currentBrowserPrincipal}),t}n(qa,"getSetup");async function hn(e){let t=e.now??new Date,r=await hr(e.csrfToken);return Ua(bp(await b().readPendingAuthorization({transactionId:r.transactionId,currentStateHash:await x(e.csrfToken),now:I(t)})))}n(hn,"getSetupTransaction");async function Cp(e){let t=await hr(e.csrfToken),r=le(),o=I(de(e.now,fp)),i=await b().decideAuthorizationSetup({decision:"approve",transactionId:t.transactionId,currentStateHash:await x(e.csrfToken),currentPrincipal:{subjectId:e.currentBrowserPrincipal.subjectId},authorizationCodeHash:await x(r),authorizationCodeExpiresAt:o,grantId:So(),now:I(e.now)});if(i.kind!=="approved")throw R(i.kind==="cancelled"?"oauth_state_invalid":fn(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(Cp,"createAuthorizationCodeRedirectWithDecision");async function vp(e){let t=await hr(e.csrfToken),r=await b().decideAuthorizationSetup({decision:"cancel",transactionId:t.transactionId,currentStateHash:await x(e.csrfToken),currentPrincipal:{subjectId:e.currentBrowserPrincipal.subjectId},now:I(e.now)});if(r.kind!=="cancelled")throw R(r.kind==="approved"?"oauth_state_invalid":fn(r.kind),"Authorization setup state is invalid, expired, or already used.");return Ap({redirectUri:r.transaction.redirectUri,clientState:r.transaction.clientState})}n(vp,"createCancelRedirectWithDecision");function Ap(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(Ap,"buildClientCancelRedirect");async function Ma(e){let t=e.now??new Date;return Cp({csrfToken:e.csrfToken,currentBrowserPrincipal:e.currentBrowserPrincipal,now:t})}n(Ma,"approve");async function Da(e){let t=e.now??new Date;return vp({csrfToken:e.csrfToken,currentBrowserPrincipal:e.currentBrowserPrincipal,now:t})}n(Da,"cancel");K();import{createRemoteJWKSet as kp,errors as ot,jwtVerify as ja,SignJWT as xp}from"jose";var _n="zuplo_mcp_session",Tp=d.object({purpose:d.literal("gateway_browser_session"),sub:ct,browserLoginOrigin:d.string().min(1),roles:d.array(d.string().min(1)).optional(),exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),Up=d.object({id_token:d.string().min(1),token_type:d.string().min(1).optional(),expires_in:d.number().optional(),access_token:d.string().min(1).optional(),refresh_token:d.string().min(1).optional(),scope:d.string().min(1).optional()}),Pp=d.object({error:d.string().min(1).optional(),error_description:d.string().min(1).optional(),error_uri:d.string().min(1).optional()}),Ep=d.object({sub:ct,nonce:d.string().min(1)}).catchall(d.unknown()),gn;function Op(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(Op,"parseCookieHeader");async function za(){return ie({purpose:"browser-session",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>Se(e,"browser-session"),"derive")})}n(za,"getBrowserSessionKey");function yn(e,t){let r=new URL(q(e,t)),o=[`${_n}=`,"Path=/","HttpOnly","SameSite=Lax","Max-Age=0"];return r.protocol==="https:"&&o.push("Secure"),o.join("; ")}n(yn,"buildBrowserSessionEvictionCookie");function qp(e){let t=new URL(q(e.requestUrl,e.requestHeaders)),r=[`${_n}=${encodeURIComponent(e.value)}`,"Path=/","HttpOnly","SameSite=Lax",`Max-Age=${e.ttlSeconds}`];return t.protocol==="https:"&&r.push("Secure"),r.join("; ")}n(qp,"serializeSessionCookie");function Ha(){return new URL(Re("url")).origin}n(Ha,"readBrowserLoginOrigin");function Mp(e){let t=Pp.safeParse(e);if(!t.success)return{};let r={};return t.data.error!==void 0&&(r.idpError=t.data.error),t.data.error_description!==void 0&&(r.idpErrorDescription=t.data.error_description.slice(0,256)),t.data.error_uri!==void 0&&(r.idpErrorUri=t.data.error_uri.slice(0,256)),r}n(Mp,"readIdpErrorFields");function Dp(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(Dp,"readJwtFailureKind");function jp(e){return e instanceof Error&&"cause"in e?e.cause:e}n(jp,"readErrorCause");function zp(e){if(e!==null&&typeof e=="object"&&"extensionMembers"in e)return e.extensionMembers?.gatewayCode}n(zp,"readRuntimeGatewayCode");function Hp(){if(!gn){let e=L();gn=kp(new URL(e.oidc.jwksUrl),{timeoutDuration:e.browserLogin.remoteTimeoutMs})}return gn}n(Hp,"readFederatedJwks");function Ba(e){if(!e.user)throw R("authentication_required","The browser login callback did not include an authenticated Zuplo principal.");return Te(e.user,e.url)}n(Ba,"resolveCurrentRequestPrincipal");async function gr(e,t={}){let r=Op(e.headers.get("cookie")).get(_n);if(!r)return{};try{let{payload:o}=await ja(r,await za(),{algorithms:[Y],issuer:$,audience:V}),i=Tp.parse(o);if(i.browserLoginOrigin!==Ha())return{evictCookie:yn(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 ot.JWTExpired?{evictCookie:yn(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:yn(e.url,e.headers)})}}n(gr,"readBrowserSession");async function yr(e){let t=L().browserLogin.sessionTtlSeconds,r={purpose:"gateway_browser_session",sub:e.principal.subjectId,browserLoginOrigin:Ha()};e.principal.roles&&(r.roles=e.principal.roles);let o=await new xp(r).setProtectedHeader({alg:Y,typ:"JWT"}).setIssuer($).setAudience(V).setIssuedAt().setExpirationTime(Math.floor(Date.now()/1e3)+t).sign(await za());return qp({value:o,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,ttlSeconds:t})}n(yr,"createBrowserSessionCookie");async function Bp(e){let t=L(),r=Re("tokenUrl"),o=Re("clientId"),i=Re("clientSecret"),a=new URL(H().actionPath("/oauth/callback"),Ge(e.requestUrl,e.requestHeaders)).toString(),c=new URLSearchParams({grant_type:"authorization_code",code:e.code,redirect_uri:a,client_id:o,client_secret:i});if(t.browserLogin.pkce===He){let s=await ln({stateId:e.stateId,signingKey:await Ut()});c.set("code_verifier",s)}try{let{response:s,json:u}=await sr(r,{method:"POST",headers:{accept:"application/json","content-type":"application/x-www-form-urlencoded"},body:c},{maxResponseBytes:32768,problemCode:"browser_login_verification_failed",timeoutMs:t.browserLogin.remoteTimeoutMs,context:e.context});if(!s.ok){let y=Mp(u);throw e.context?.log.warn({event:"federated_token_exchange_failed",code:"provider_access_denied",idpHost:O(r),idpStatus:s.status,...y},"Federated browser login token exchange returned non-2xx from the identity provider"),R({code:"provider_access_denied",privateDetail:"Federated browser login token exchange failed.",cause:new Error(`IdP token exchange failed (status=${s.status}${y.idpError?` idp_error=${y.idpError}`:""}${y.idpErrorDescription?` idp_error_description=${y.idpErrorDescription}`:""})`)})}let p=Up.parse(u),f;try{({payload:f}=await ja(p.id_token,Hp(),{issuer:t.oidc.issuer,audience:o}))}catch(y){let P={};throw N(P,"error",y),e.context?.log.warn({event:"federated_id_token_verification_failed",code:"browser_login_verification_failed",failureKind:Dp(y),idpHost:O(r),expectedIssuer:t.oidc.issuer,...P},"Federated id_token failed jose verification"),y}if(f.nonce!==e.nonce)throw e.context?.log.warn({event:"federated_nonce_mismatch",code:"oauth_callback_mismatch",idpHost:O(r),nonceMissingFromIdToken:f.nonce===void 0},"Federated id_token nonce did not match the signed gateway state"),R("oauth_callback_mismatch","Federated browser login nonce did not match the signed gateway state.");let w=Ep.parse(f);return{principal:Te({sub:w.sub,data:w},e.requestUrl),subjectToken:{token:p.id_token,tokenType:ut,expiresAt:typeof f.exp=="number"?I(new Date(f.exp*1e3)):void 0}}}catch(s){let u=ce(s)??zp(s);throw u!==void 0&&u!=="browser_login_verification_failed"?s:R("browser_login_verification_failed","Federated browser login callback could not be verified.",jp(s))}}n(Bp,"exchangeFederatedAuthorizationCode");async function La(e){let t=typeof e.request.query.code=="string"?e.request.query.code:void 0;if(t)return Bp({code:t,nonce:e.stateId,stateId:e.stateId,requestUrl:e.request.url,requestHeaders:e.request.headers,context:e.context});let r=await gr(e.request,{context:e.context});if(r.principal)return{principal:r.principal};throw R("oauth_callback_mismatch","Federated browser login callback is missing an authorization code.")}n(La,"resolveBrowserLoginCallbackIdentity");K();var Lp=new Set(["about","blob","data","file","ftp","ftps","javascript","mailto","urn","ws","wss"]);function Np(e){return e.protocol.replace(/:$/u,"").toLowerCase()}n(Np,"readScheme");function Jp(e){return e.protocol==="https:"}n(Jp,"isSpecCompliantRedirectUri");function Gp(e){let t=Np(e);return t.length>0&&t!=="http"&&t!=="https"&&!Lp.has(t)}n(Gp,"isNativeAppCustomSchemeRedirectUri");var Ja=[{id:"oauth.redirect_uri.https",mode:"strict",accepts:n(e=>Jp(e),"accepts")},{id:"oauth.redirect_uri.loopback_http",mode:"native_app",accepts:n(e=>W(e),"accepts"),matches:n((e,t)=>W(e)&&W(t)&&e.pathname===t.pathname&&e.search===t.search,"matches")},{id:"oauth.redirect_uri.custom_scheme",mode:"native_app",accepts:n(e=>Gp(e),"accepts")}];function Ga(e){let t=Ja.find(r=>r.accepts(e.url));return t===void 0?{kind:"rejected"}:{kind:"allowed",ruleId:t.id,mode:t.mode}}n(Ga,"evaluateBuiltInRedirectUriCompatibility");function Na(e){try{return new URL(e)}catch{return}}n(Na,"parseUrl");function Fa(e){if(e.registeredRedirectUri===e.requestedRedirectUri)return!0;let t=Na(e.registeredRedirectUri),r=Na(e.requestedRedirectUri);return t===void 0||r===void 0?!1:Ja.some(o=>o.matches?.(t,r))}n(Fa,"redirectUriMatchesBuiltInCompatibility");var Fp=1e4,$p=5*1024,Zp=0,Kp=2160*60*60,$a=["authorization_code","refresh_token",$t,be],Wp=["authorization_code","refresh_token"],Za=[Ro],Vp=["code"],Yp=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($a)).min(1).max($a.length).optional(),authorization_grant_profiles_supported:d.array(d.enum(Za)).min(1).max(Za.length).optional(),response_types:d.array(d.enum(Vp)).min(1).max(1).optional(),scope:d.literal(M).optional(),token_endpoint_auth_method:Io.optional(),jwks_uri:d.string().min(1).optional()});function Xp(e){try{let t=new URL(e);return(t.protocol==="https:"||t.protocol==="http:"&&W(t))&&t.pathname!=="/"}catch{return!1}}n(Xp,"isCimdClientIdCandidate");function Ka(e,t){throw new m("invalid_client",Po({clientId:e})??"OAuth client is not registered.",void 0,t===void 0?void 0:{cause:t})}n(Ka,"invalidCimdClientError");function it(e,t="invalid_request"){if(Qp(e))throw new m(t,"redirect_uris must not include raw whitespace or control characters.");let r;try{r=new URL(e)}catch{throw new m(t,"redirect_uris must be absolute URIs.")}if(r.hash||r.username||r.password)throw new m(t,"redirect_uris must not include credentials or fragments.");if(Ga({url:r}).kind==="rejected")throw new m(t,"redirect_uris must use HTTPS, loopback HTTP, or a native-app private-use URI scheme.")}n(it,"assertValidRedirectUri");function Qp(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(Qp,"hasForbiddenRawRedirectUriCharacter");async function em(e){let{response:t,json:r}=await di(e.initialUrl,{headers:{accept:"application/json"}},{maxRedirects:Zp,maxResponseBytes:$p,timeoutMs:Fp});if(!t.ok)throw R("invalid_request","CIMD metadata could not be fetched.");let o=Kt(r);for(let i of o.redirect_uris)it(i,"invalid_request");if(o.jwks_uri!==void 0&&pt(o.jwks_uri),o.client_id!==e.clientId)throw R("invalid_request","Fetched CIMD client_id must exactly match the requested client_id.");return o}n(em,"fetchCimdMetadata");async function tm(e){let t=Wt(e),r=await em({clientId:e,initialUrl:t});return{kind:"cimd",clientId:e,metadata:r}}n(tm,"resolveCimdClient");async function _r(e,t){let r=ue.parse(e);if(Xp(r)){L().gateway.downstreamCimdEnabled||Ka(r);try{return await tm(r)}catch(i){Ka(r,i)}}let o=await b().readClient({clientId:r});if(o.kind==="found"){let i=o.client,a=Oo(i.clientId),c=a===void 0?i.tokenEndpointAuthMethod:"private_key_jwt",s=i.jwksUri??a;if(c==="private_key_jwt"&&s===void 0)throw new m("invalid_client","Dynamic private_key_jwt client is missing JWKS metadata. Re-run client registration before authorization.");let u=Kt({client_id:i.clientId,client_name:i.clientName,redirect_uris:i.redirectUris,token_endpoint_auth_method:c,...s===void 0?{}:{jwks_uri:s}}),p={kind:"dcr",clientId:r,metadata:u};return i.hashedClientSecret&&(p.hashedClientSecret=i.hashedClientSecret),p}throw new m("invalid_client",r.startsWith("dcr:")?"Dynamic client is not registered. Re-run client registration before authorization.":"OAuth client is not registered.")}n(_r,"resolveClient");function Wa(e,t){if(!e.metadata.redirect_uris.some(r=>Fa({registeredRedirectUri:r,requestedRedirectUri:t})))throw R("invalid_request","redirect_uri is not registered for the client.")}n(Wa,"assertRedirectRegistered");function rm(e){return e===void 0?[...Wp]:Array.from(new Set(e))}n(rm,"normalizeGrantTypes");function nm(e){try{pt(e)}catch(t){throw new m("invalid_client_metadata","jwks_uri must be an HTTPS URL with a path, no credentials or fragment, and must not point at a blocked host.",void 0,{cause:t})}}n(nm,"assertValidDcrJwksUri");function om(e){return e.tokenEndpointAuthMethod==="private_key_jwt"&&e.jwksUri!==void 0?ue.parse(Eo({clientId:crypto.randomUUID(),jwksUri:e.jwksUri})):ue.parse(`dcr:${crypto.randomUUID()}`)}n(om,"createDcrClientId");function at(e){if(e===void 0||e===M)return M;throw new m("invalid_request",`Only the ${M} scope is supported.`)}n(at,"assertSupportedOAuthScope");function Me(e,t,r){let o;try{o=new URL(t)}catch{throw new m("invalid_target","resource must be an absolute URI.")}if(o.hash)throw new m("invalid_target","resource must not include a fragment.");if(o.protocol!=="https:"&&!W(o))throw new m("invalid_target","resource must use HTTPS except loopback HTTP resources in local development.");let i=q(e,r),a=_o(),c=a?[...a.byOperationId.values()].find(s=>new URL(s.routePath,i).toString()===t):void 0;if(!c)throw new m("invalid_target","resource must match a published MCP route.");return c}n(Me,"resolveResource");async function Va(e){let t;try{t=Yp.parse(e)}catch(y){if(y instanceof d.ZodError){let P=y.issues.some(k=>k.path[0]==="redirect_uris");throw new m(P?"invalid_redirect_uri":"invalid_client_metadata",y.issues[0]?.message??"Client metadata is invalid.",void 0,{cause:y})}throw y}for(let y of t.redirect_uris)it(y,"invalid_redirect_uri");if(t.token_endpoint_auth_method==="private_key_jwt"&&t.jwks_uri===void 0)throw new m("invalid_client_metadata","jwks_uri is required for private_key_jwt clients.");t.jwks_uri!==void 0&&nm(t.jwks_uri);let r=new Date,o=t.token_endpoint_auth_method??"none",i=o==="private_key_jwt"?"none":o,a=om({tokenEndpointAuthMethod:o,jwksUri:t.jwks_uri}),c=Kt({client_id:a,client_name:t.client_name??"Dynamically registered MCP client",redirect_uris:t.redirect_uris,token_endpoint_auth_method:o,...t.jwks_uri===void 0?{}:{jwks_uri:t.jwks_uri}}),s=de(r,Kp),u=Math.floor(r.getTime()/1e3),p=Math.floor(s.getTime()/1e3),f={client_id:c.client_id,client_name:c.client_name,redirect_uris:c.redirect_uris,grant_types:rm(t.grant_types),authorization_grant_profiles_supported:t.authorization_grant_profiles_supported,response_types:["code"],scope:M,token_endpoint_auth_method:c.token_endpoint_auth_method,client_id_issued_at:u,jwks_uri:c.jwks_uri},w={clientId:c.client_id,clientName:c.client_name,redirectUris:c.redirect_uris,tokenEndpointAuthMethod:i,createdAt:I(r),clientExpiresAt:I(s)};if(o==="client_secret_basic"||o==="client_secret_post"){let y=le();w.hashedClientSecret=await x(y),w.clientSecretExpiresAt=I(s),f.client_secret=y,f.client_secret_expires_at=p,f.client_secret_issued_at=u}if((await b().registerClient(w)).kind==="already_exists")throw R("invalid_request","OAuth client is already registered.");return f}n(Va,"registerDownstreamClient");function im(e){return e?.metadata?.idpSubjectTokenType!==Fe&&e?.metadata?.idpSubjectTokenExpiresAt!==void 0&&new Date(e.metadata.idpSubjectTokenExpiresAt).getTime()<=Date.now()?!1:e?.status==="active"&&e.metadata?.encryptedIdpSubjectToken!==void 0&&e.metadata.idpSubjectTokenType!==void 0}n(im,"hasStoredIdJagSubjectTokenBinding");async function Ya(e){let t=Je(e.principal.subjectId);return(await b().batchGetUpstreamConnections([{owner:t,upstreamServerId:e.connection.upstreamServerId,authProfileId:e.connection.authProfileId}]))[0]}n(Ya,"readIdJagSubjectConnection");async function wn(e){let t=te().byOperationId.get(e.operationId);if(t?.connection===void 0||t.connection.authMode!=="id-jag")return!1;let r=await Ya({connection:t.connection,principal:e.principal});return!im(r)}n(wn,"requiresIdJagSubjectTokenBinding");async function Xa(e){if(e.subjectToken===void 0)return;let t=te().byOperationId.get(e.transaction.operationId);if(t?.connection===void 0||t.connection.authMode!=="id-jag"||e.principal.subjectId!==e.transaction.principal.subjectId)return;let r=await Ya({connection:t.connection,principal:e.principal});return b().upsertUpstreamConnection({id:r?.id??Vt(),ownerMode:"user",subjectId:e.transaction.principal.subjectId,upstreamServerId:t.connection.upstreamServerId,authProfileId:t.connection.authProfileId,status:"active",encryptedAccessToken:r?.encryptedAccessToken,encryptedRefreshToken:r?.encryptedRefreshToken,scopes:r?.scopes??[],expiresAt:r?.expiresAt,metadata:{...r?.metadata??{},encryptedIdpSubjectToken:await me(e.subjectToken.token),idpSubjectTokenType:e.subjectToken.tokenType,idpSubjectTokenExpiresAt:e.subjectToken.expiresAt}})}n(Xa,"bindIdJagSubjectTokenForAuthorizationTransaction");function wr(e){return C`<img class="card__icon" src="${e.iconHref}" alt="" width="48" height="48" referrerpolicy="no-referrer" onerror=" this.onerror = null; this.src = '${e.fallbackIconHref}'; " />`}n(wr,"renderShellIcon");function Qa(e){return C`<form class="actions" method="post" action="${e.setupAction}" ${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(Qa,"renderActions");var es=fe('<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 ts(e){return C`<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(ts,"renderBannerWarning");var YR=fe('<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>'),XR=fe('<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 QR=fe('<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 am="data:,",rs=C`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);"`,ns=C`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 sm(e,t,r){if(e)try{let o=new URL(t).origin,i=new URL(e,o);return i.origin!==o||!i.pathname.startsWith(r.actionPath("/auth/connections/"))?void 0:i.toString()}catch{return}}n(sm,"safeGatewayConnectHref");function cm(e){return e.some(r=>r.ownerMode==="user"&&r.status!=="active")?"setup":"grant"}n(cm,"deriveMode");function dm(e){return Qa({state:e.state,setupAction:e.gateway.actionPath("/oauth/setup"),submitOnceAttrs:rs,authorizeAttrs:re})}n(dm,"renderActions");function Rn(e,t,r,o){for(let i of e){if(i.ownerMode!=="user"||i.status!==r)continue;let a=sm(i.connectUrl,t,o);if(a)return a}}n(Rn,"firstUserConnectHref");function um(e){let t=e.connectHref===void 0?re:C`<a class="button button--primary" href="${e.connectHref}" ${ns}>Connect</a>`;return C`<form class="actions" method="post" action="${e.gateway.actionPath("/oauth/setup")}" ${rs}><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(um,"renderSetupActions");function lm(e){return e?C`<span class="reconnect-action"><a class="button button--secondary reconnect-button" href="${e}" ${ns}>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>`:re}n(lm,"renderReconnectAction");function pm(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(pm,"isRenderableIconHref");function os(e){return e?.find(t=>pm(t.src))?.src}n(os,"readIconHref");function mm(e){return os(e.serverIcons)??(e.transportHost===void 0?void 0:Wr(e.transportHost).src)}n(mm,"readUpstreamIconHref");function fm(e){let t=os(e.routeIcons);if(t!==void 0)return t;for(let r of e.upstreams){let o=mm(r);if(o!==void 0)return o}}n(fm,"readHeaderIconHref");function hm(e){let t=e.setupMessage===void 0?re:ts({icon:es,message:e.setupMessage});return C`<p class="card__subtitle">Authorize '<strong>${e.clientDisplayName}</strong>' to access '<strong>${e.routeDisplayName}</strong>' on your behalf?</p>${t}`}n(hm,"renderBody");function bn(e){let t=cm(e.upstreams),r=Rn(e.upstreams,e.gatewayOrigin,"not_connected",e.gateway),o=Rn(e.upstreams,e.gatewayOrigin,"reconsent_required",e.gateway),i=Rn(e.upstreams,e.gatewayOrigin,"active",e.gateway),a=t==="setup"?r??o:void 0,c=t==="setup"?e.upstreams.find(p=>p.ownerMode==="user"&&p.status!=="active"&&p.connectUrl===void 0&&p.setupMessage!==void 0)?.setupMessage:void 0,s=fm({routeIcons:e.routeIcons,upstreams:e.upstreams}),u=t==="setup"?C`<footer class="card__footer">${um({state:e.state,connectHref:a,gateway:e.gateway})}</footer>`:C`<footer class="card__footer">${lm(i)}${dm({state:e.state,gateway:e.gateway})}</footer>`;return et(rt({title:`Authorize access \xB7 ${e.routeDisplayName}`,iconHref:s??am,styles:tt,headerIcon:s===void 0?re:wr({iconHref:s,fallbackIconHref:nr}),heading:"Authorize access",subhead:re,body:hm({routeDisplayName:e.routeDisplayName,clientDisplayName:e.clientDisplayName,setupMessage:c}),footer:u}))}n(bn,"renderConsentPage");var gm=1e4,is="mcp-session-id",ym;function us(){return{tools:[],prompts:[],resources:[]}}n(us,"emptyCapabilities");function as(){return new Headers({accept:"application/json, text/event-stream","content-type":"application/json","mcp-protocol-version":Er})}n(as,"buildReadinessHeaders");async function ss(e){if(e.type==="bearer_token"){let o=as();return o.set("authorization",`Bearer ${e.token}`),o}let t=await e.provider.tokens();if(!t)return;let r=as();return r.set("authorization",`${t.token_type??"Bearer"} ${t.access_token}`),r}n(ss,"buildAsyncCredentialHeaders");function cs(e){return new Request(e.upstreamUrl,{method:"POST",headers:e.headers,body:JSON.stringify(Gt.parse({jsonrpc:Jt,id:1,method:"initialize",params:{protocolVersion:Er,capabilities:{},clientInfo:{name:"zuplo-mcp-gateway-readiness",version:"0.0.0"}}}))})}n(cs,"buildInitializePreflight");async function In(e){lt(e.url);let t=new AbortController,r=setTimeout(()=>t.abort(),gm);try{let o=new Request(e,{redirect:"manual",signal:t.signal});return await jt.fetch(o)}finally{clearTimeout(r)}}n(In,"runPreflight");function Sn(e){e.body?.cancel().catch(()=>{})}n(Sn,"releasePreflightBody");async function _m(e){let t=e.response.headers.get(is);if(!t)return;let r=new Headers(e.headers);r.set(is,t),r.delete("content-type");try{let o=await In(new Request(e.upstreamUrl,{method:"DELETE",headers:r}));Sn(o)}catch{}}n(_m,"terminatePreflightSession");async function ls(e){let{response:t}=e;return Sn(t),t.status>=200&&t.status<300?(await _m(e),{kind:"ready",upstreamStatus:t.status,capabilities:us()}):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(ls,"classifyResponse");function ds(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(ds,"connectRequiredResult");async function wm(e){try{return ls({response:await In(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(wm,"classifyPreflight");async function Rm(e){let t=e.route.connection;if(t===void 0)return{kind:"ready",upstreamStatus:204,capabilities:us()};let r=pr(t.upstreamServerId,e.route.operationId),o=Qe(r,e.subjectId),i=e.returnTo===void 0?o:{...o,returnTo:e.returnTo},a=new Request(e.requestUrl,{headers:e.requestHeaders}),c=await Xe({request:a,routeAuth:i,preloadedConnection:e.preloadedConnection});if(c.kind==="connect_required")return ds(c.payload);let s=await ss(c.credential);if(s===void 0)return{kind:"upstream_auth_rejected",status:401,message:"Upstream credential did not produce tokens."};let u=cs({upstreamUrl:t.mcpUrl,headers:s}),p;try{p=await In(u)}catch(U){return{kind:"upstream_unavailable",message:U instanceof Error?U.message:"Upstream MCP server readiness preflight failed."}}if(p.status!==401)return ls({response:p,upstreamUrl:t.mcpUrl,headers:s});Sn(p);let f=await Xe({request:a,routeAuth:i,forceRefresh:!0,preloadedConnection:e.preloadedConnection});if(f.kind==="connect_required")return ds(f.payload);let w=await ss(f.credential);return w===void 0?{kind:"upstream_auth_rejected",status:401,message:"Upstream credential did not produce tokens after refresh."}:wm({request:cs({upstreamUrl:t.mcpUrl,headers:w}),upstreamUrl:t.mcpUrl,headers:w})}n(Rm,"checkUpstreamRouteReadinessImpl");function ps(e){return(ym??Rm)(e)}n(ps,"checkUpstreamRouteReadiness");function bm(e){try{return new URL(e).host}catch{return}}n(bm,"safeUrlHost");function ms(e){return e!==void 0&&e.length>0}n(ms,"hasItems");function Im(e){let t=e.serverInfo?.icons;if(ms(t))return t;let r=or(e.mcpUrl);return r===void 0?void 0:[r]}n(Im,"readServerIcons");async function Sm(e){let{authConfig:t,authMode:r,description:o,displayName:i,mcpUrl:a,ownerMode:c,upstreamServerId:s,authProfileId:u}=e.registeredConnection,p=c==="user",f=p&&r!=="id-jag",w=e.readiness??(p?jo(e.connection):{connected:!0,status:"active"}),U=f?e.readiness?.connectUrl??(e.returnTo!==void 0?await Xr({requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,owner:e.userOwner,initiatedBySubjectId:e.transaction.principal.subjectId,upstreamServerId:s,authProfileId:u,operationId:e.route.operationId,returnTo:e.returnTo}):void 0):void 0,y=t.mode==="id-jag"?t.idJag.scopes:t.oauth.scopes;return{upstreamServerId:s,authProfileId:u,authMode:r,ownerMode:c,upstreamDisplayName:i,description:o,transportHost:bm(a),scopesRequested:ms(y)?y:void 0,serverIcons:Im(e.registeredConnection),status:w.status,connected:w.connected,capabilities:{tools:[],prompts:[],resources:[]},connectUrl:U,setupMessage:e.setupMessage,updatedAt:p&&"updatedAt"in w&&w.updatedAt!==void 0?w.updatedAt:void 0,expiresAt:e.readiness?.expiresAt??e.connection?.expiresAt}}n(Sm,"buildSetupRequirement");function fs(e){let t=te().byOperationId.get(e);if(!t)throw R("unknown_mcp_route",`Unknown MCP route: ${e}`);return t}n(fs,"requireRoute");async function Cn(e){let t=fs(e.transaction.operationId),r=Je(e.transaction.principal.subjectId),o=t.connection;if(o===void 0)return[];let a=o.ownerMode==="user"?(await b().batchGetUpstreamConnections([{owner:r,upstreamServerId:o.upstreamServerId,authProfileId:o.authProfileId}]))[0]:void 0,c=await ps({requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,route:t,subjectId:e.transaction.principal.subjectId,preloadedConnection:a,returnTo:e.returnTo}),s="connectionStatus"in c?c.connectionStatus:void 0,u=(c.kind==="connect_required"||c.kind==="admin_setup_required")&&c.payload.authUrl!==void 0?c.payload.authUrl:void 0,p=c.kind==="admin_setup_required"?c.payload.message:void 0;return[await Sm({connection:a,registeredConnection:o,route:t,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,returnTo:e.returnTo,transaction:e.transaction,userOwner:r,setupMessage:p,readiness:s===void 0?void 0:{...s,connectUrl:u}})]}n(Cn,"requirementsForSetup");async function vn(e){let t=fs(e.transaction.operationId),r=await b().readClient({clientId:e.transaction.clientId}),o=r.kind==="found"?r.client:void 0,i={gatewayOrigin:q(e.requestUrl,e.requestHeaders),routeDisplayName:t.connection?.displayName??t.operationId,clientDisplayName:o?.clientName??String(e.transaction.clientId),principalLabel:e.transaction.principal.subjectId},a=t.connection?.description;return a!==void 0&&(i.routeDescription=a),i}n(vn,"consentContext");function An(e){return e.some(t=>t.ownerMode==="user"&&t.status!=="active")}n(An,"hasUnresolvedUserUpstream");var Cm=["mcp_user"],vm="dev-browser-user",Am=["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(" "),km=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:eo,state:d.string().min(1).optional(),scope:d.literal(M).default(M)}),xm=d.enum(["continue","approve","cancel"]).default("continue"),Tm=d.object({state:d.string().min(1),decision:xm}),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 hs(e){return typeof e=="string"&&e.length>0?e:void 0}n(hs,"readQueryString");function Um(e,t){let r=hs(e.query.resource);if(t===void 0){if(r!==void 0)return r;throw new m("invalid_target",Am)}let o=ko(t,e.url,e.headers);if(r===void 0||r===o)return o;throw new m("invalid_target","resource must match the scoped OAuth authorization endpoint resource.")}n(Um,"requireAuthorizeResource");async function Pm(e,t){let r={};t!==void 0&&(r.context=t);let o=await gr(e,r);if(o.principal)return{principal:o.principal};if(!e.user)return o.evictCookie===void 0?{}:{setCookie:o.evictCookie};let i=Ba(e);return{principal:i,setCookie:await yr({principal:i,requestUrl:e.url,requestHeaders:e.headers})}}n(Pm,"resolveBrowserPrincipal");async function Em(e,t){let r={};t!==void 0&&(r.context=t);let o=await gr(e,r);if(!o.principal)throw R("authentication_required","Authorization setup requires a current browser session.");return o.principal}n(Em,"requireSetupPrincipal");function gs(e){return`${H().actionPath("/oauth/setup")}?state=${encodeURIComponent(e)}`}n(gs,"buildSetupReturnTo");async function ys(e){let t=await Cn({transaction:e.transaction,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,returnTo:gs(e.csrfToken)}),r=await vn({transaction:e.transaction,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders}),o={kind:"setup_page",html:bn({state:e.csrfToken,operationId:e.transaction.operationId,gateway:H(),upstreams:t,...r})};return e.setCookie!==void 0&&(o.setCookie=e.setCookie),o}n(ys,"renderSetup");function Om(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(Om,"toAuthorizationTransactionClient");async function kn(e,t={}){let r=km.parse({...e.query,resource:Um(e,t.operationId),state:hs(e.query.state)}),o=at(r.scope);it(r.redirect_uri,"invalid_request");let i=new Date,a=ue.parse(r.client_id),c=await _r(r.client_id,i);Wa(c,r.redirect_uri);try{let s=Me(e.url,r.resource,e.headers),u=Om(c);t.context?.log.info({event:"oauth_authorize_request_parsed",clientId:a,operationId:s.operationId,scope:o,hasClientState:r.state!==void 0},"Downstream OAuth authorize: request parsed and client resolved"),t.context&&v(t.context,{eventType:S.MCP_OAUTH_AUTHORIZE_STARTED,outcome:"success",virtualServerName:s.operationId,attributes:{clientId:a,scope:o,responseType:r.response_type}});let p={clientId:c?.clientId??a,...u===void 0?{}:{client:u},redirectUri:r.redirect_uri,resource:r.resource,operationId:s.operationId,scope:o,codeChallenge:r.code_challenge,codeChallengeMethod:r.code_challenge_method,...r.state===void 0?{}:{clientState:r.state}},{principal:f,setCookie:w}=await Pm(e,t.context),U=f===void 0?!1:await wn({operationId:s.operationId,principal:f});if(!f||U){let P=await Pa({transaction:p,requestUrl:e.url,requestHeaders:e.headers,now:i});t.context?.log.info({event:"oauth_authorize_awaiting_login",clientId:a,operationId:s.operationId,reason:f?"id_jag_subject_binding_missing":"no_browser_session"},"Downstream OAuth authorize: redirecting to browser login");let k={kind:"redirect",location:P.browserLoginUrl};return w!==void 0&&(k.setCookie=w),k}let y=await Ea({transaction:p,principal:f,now:i});return t.context?.log.info({event:"oauth_authorize_awaiting_setup",clientId:a,operationId:s.operationId,subjectId:f.subjectId},"Downstream OAuth authorize: rendering consent/setup page"),t.context&&v(t.context,{eventType:S.MCP_OAUTH_AUTHORIZE_AWAITING_SETUP,outcome:"success",virtualServerName:s.operationId,attributes:{clientId:a,scope:o,responseType:r.response_type,subjectId:f.subjectId}}),ys({transaction:y.transaction,csrfToken:y.csrfToken,requestUrl:e.url,requestHeaders:e.headers,setCookie:w})}catch(s){throw qm({redirectUri:r.redirect_uri,clientState:r.state,cause:s})}}n(kn,"authorizeDownstreamClient");function qm(e){if(e.cause instanceof Ae)return e.cause;let t=Mm(e.cause);return t?new Ae({redirectUri:e.redirectUri,clientState:e.clientState,errorCode:t.errorCode,errorDescription:t.errorDescription,cause:e.cause}):e.cause}n(qm,"toDownstreamAuthorizeRedirectError");function Mm(e){if(e instanceof m)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(Mm,"mapToOAuthRedirectError");async function _s(e,t={}){let r=typeof e.query.error=="string"?e.query.error:void 0;if(r){let p=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,...p===void 0?{}:{idpErrorDescription:p},...f===void 0?{}:{idpErrorUri:f}},"Identity provider redirected browser-login callback with an error"),R("provider_access_denied",p??"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"),R("oauth_state_invalid","Browser login callback is missing state.");let i=await pn(o),a={request:e,stateId:i.stateId};t.context!==void 0&&(a.context=t.context);let c=await La(a),s=await Oa({browserLoginStateToken:o,principal:c.principal});if(await Xa({transaction:s.transaction,principal:c.principal,subjectToken:c.subjectToken}),await wn({operationId:s.transaction.operationId,principal:c.principal}))throw R("browser_login_verification_failed","The identity provider did not return the subject token required for XAA / ID-JAG.");let u=await ys({transaction:s.transaction,csrfToken:s.csrfToken,requestUrl:e.url,requestHeaders:e.headers});return u.setCookie=await yr({principal:c.principal,requestUrl:e.url,requestHeaders:e.headers}),u}n(_s,"completeBrowserLoginCallback");async function ws(e){let t=L(),r=new URL(e.url);if(!W(r))throw R("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 R("oauth_state_invalid","Local browser login is missing state.");let i=H().actionPath("/oauth/callback"),a=new URL(typeof e.query.redirect_uri=="string"?e.query.redirect_uri:i,q(e.url)),c=new URL(q(e.url)).origin;if(a.origin!==c||a.pathname!==i)throw R("oauth_callback_mismatch",`Local browser login redirect_uri must target this gateway's ${i} route.`);a.searchParams.set("state",o);let s={subjectId:ct.parse(vm),roles:Cm};return{kind:"redirect",location:a,setCookie:await yr({principal:s,requestUrl:e.url,requestHeaders:e.headers})}}n(ws,"completeLocalDevBrowserLogin");function Dm(e){let t=e.method==="POST"?e.body:e.query;return Tm.parse(t)}n(Dm,"readSetupContinueRequest");async function Rs(e){let{state:t,decision:r}=Dm({method:e.request.method,query:e.request.query,body:e.body}),o=new Date,i=await hn({csrfToken:t,now:o}),a=await Em(e.request,e.context);if(r==="cancel")return{kind:"redirect",location:await Da({csrfToken:t,currentBrowserPrincipal:a,now:o})};let c=await qa({csrfToken:t,currentBrowserPrincipal:a,now:o}),s=await Cn({transaction:c,requestUrl:e.request.url,requestHeaders:e.request.headers,returnTo:gs(t)});if(r==="approve"&&An(s)&&await Ta({csrfToken:t,currentBrowserPrincipal:a,now:o}),An(s)){let u=await vn({transaction:c,requestUrl:e.request.url,requestHeaders:e.request.headers});return{kind:"setup_page",html:bn({state:t,operationId:c.operationId,gateway:H(),upstreams:s,...u})}}return{kind:"redirect",location:await Ma({csrfToken:t,currentBrowserPrincipal:a,now:o})}}n(Rs,"continueDownstreamAuthorizeSetup");K();import{createLocalJWKSet as Wm,decodeJwt as Vm,errors as Et,jwtVerify as Ym}from"jose";K();import{createRemoteJWKSet as jm,decodeJwt as zm,decodeProtectedHeader as Hm,errors as Pt,jwtVerify as Bm}from"jose";var vs=30,T=d.string().min(1),Lm=d.union([T,d.array(T).min(1)]),Nm=d.union([T,d.array(T).min(1)]),Jm=d.object({type:T,locations:d.array(T).optional(),actions:d.array(T).optional(),datatypes:d.array(T).optional(),identifier:T.optional(),privileges:d.array(T).optional()}).passthrough(),Gm=d.object({iss:d.url(),sub:T,aud:Lm,client_id:T,resource:Nm.optional(),scope:T.optional(),authorization_details:d.array(Jm).optional(),jti:T,iat:d.number().int(),nbf:d.number().int().optional(),exp:d.number().int(),tenant:T.optional(),aud_tenant:T.optional(),aud_sub:T.optional(),sub_id:T.optional(),act:d.unknown().optional(),email:T.optional(),auth_time:d.number().int().optional(),acr:T.optional(),amr:d.array(T).optional(),cnf:d.unknown().optional()}).passthrough();function X(e){throw new m("invalid_grant",e)}n(X,"throwInvalidGrant");function Fm(e){return e instanceof Pt.JWTExpired?"expired":e instanceof Pt.JWTClaimValidationFailed?"claim":e instanceof Pt.JWSSignatureVerificationFailed?"signature":e instanceof Pt.JWKSNoMatchingKey?"jwks_no_match":e instanceof Pt.JWTInvalid?"invalid":e instanceof d.ZodError?"schema":"other"}n(Fm,"readJwtFailureKind");function $m(e){return Array.isArray(e.aud)?(e.aud.length!==1&&X("ID-JAG audience must contain exactly one value."),e.aud[0]):e.aud}n($m,"readSingleAudience");function bs(e){try{let t=Gm.parse(e);return $m(t),t}catch(t){if(t instanceof m)throw t;X("ID-JAG claims are invalid.")}}n(bs,"parseIdJagClaims");function Zm(e,t){e.idJag.enabled||X("ID-JAG grant is not enabled.");let r=e.idJag.trustedIssuers.find(o=>o.issuer===t);return r===void 0&&X("ID-JAG issuer is not trusted."),r}n(Zm,"readTrustedIssuer");function Km(e){let t=e.authorizationDetails;if(t===void 0)return;if(e.allowedTypes===void 0)return t;let r=new Set(e.allowedTypes);return t.filter(o=>r.has(o.type))}n(Km,"readGrantedAuthorizationDetails");function Is(e){if(e.clientAuth.method==="none")throw new m("invalid_client","Client authentication failed.");e.claims.client_id!==e.authenticatedClientId&&X("ID-JAG client_id must match the authenticated client."),e.trustedIssuer.expectedClientIds!==void 0&&!e.trustedIssuer.expectedClientIds.includes(e.claims.client_id)&&X("ID-JAG client_id is not allowed for this issuer.")}n(Is,"assertClientBinding");function Ss(e){e.cnf!==void 0&&X("ID-JAG cnf-bound assertions require DPoP support.")}n(Ss,"assertProofOfPossessionNotDeferred");function Cs(e){let t=Math.floor(e.now.getTime()/1e3)+vs;e.claims.iat>t&&X("ID-JAG iat must not be in the future.")}n(Cs,"assertIssuedAtNotInFuture");async function As(e){let t;try{t=Hm(e.assertion)}catch{X("ID-JAG assertion is malformed.")}t.typ!==Ar&&X('ID-JAG header typ must be "oauth-id-jag+jwt".');let r;try{r=bs(zm(e.assertion))}catch(s){if(s instanceof m)throw s;X("ID-JAG assertion is malformed.")}let o=Ge(e.requestUrl,e.requestHeaders),i=[o];e.requestedResource!==void 0&&e.requestedResource!==o&&i.push(e.requestedResource);let a=Zm(e.config,r.iss);i.includes(r.iss)&&X("ID-JAG issuer must be different from the gateway."),Is({claims:r,trustedIssuer:a,authenticatedClientId:e.authenticatedClientId,clientAuth:e.clientAuth}),Ss(r),Cs({claims:r,now:e.now});let c;try{let s=jm(new URL(a.jwksUrl)),{payload:u}=await Bm(e.assertion,s,{issuer:a.issuer,audience:i,currentDate:e.now,clockTolerance:vs,typ:Ar});c=bs(u)}catch(s){e.context?.log.warn({event:"oauth_id_jag_verification_failed",issuer:a.issuer,failureKind:Fm(s)},"OAuth ID-JAG assertion verification failed"),X("ID-JAG assertion verification failed.")}return Is({claims:c,trustedIssuer:a,authenticatedClientId:e.authenticatedClientId,clientAuth:e.clientAuth}),Ss(c),Cs({claims:c,now:e.now}),{claims:c,trustedIssuer:a,subjectId:xo({issuer:c.iss,subject:c.sub,gatewayIssuer:o,subjectMapping:a.subjectMapping,tenant:c.tenant}),grantedAuthorizationDetails:Km({authorizationDetails:c.authorization_details,allowedTypes:e.config.idJag.enabled?e.config.idJag.authorizationDetailsTypesAllowed:void 0})}}n(As,"verifyIdJagAssertion");var Xm=new Set(["authorization_code","refresh_token",be]),Qm=1e4,ef=32*1024,tf=2,rf=3600,xn=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()}),nf=d.discriminatedUnion("grant_type",[xn.extend({grant_type:d.literal("authorization_code"),code:d.string().min(1),redirect_uri:d.string().min(1),code_verifier:Be,resource:d.url().optional(),scope:d.literal(M).optional()}),xn.extend({grant_type:d.literal("refresh_token"),refresh_token:d.string().min(1),resource:d.url().optional(),scope:d.literal(M).optional()}),xn.extend({grant_type:d.literal(be),assertion:d.string().min(1),resource:d.url().optional(),scope:d.literal(M).optional(),authorization_details:d.string().min(1).optional()})]);function of(e){if(typeof e!="object"||e===null)return;let t=e.grant_type;if(t!==void 0&&(typeof t!="string"||!Xm.has(t)))throw new m("unsupported_grant_type",`Grant type "${typeof t=="string"?t:""}" is not supported.`)}n(of,"assertSupportedGrantType");var af=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()}),sf=d.object({keys:d.array(d.record(d.string(),d.unknown())).min(1)}).passthrough();function xs(){return L().gateway.accessTokenTtlSeconds}n(xs,"readAccessTokenTtlSeconds");function cf(){return L().gateway.refreshTokenTtlSeconds}n(cf,"readRefreshTokenTtlSeconds");function ks(e,t){let r=xs(),o=Math.max(1,Math.floor((new Date(t).getTime()-e.getTime())/1e3)),i=Math.min(r,o);return{expiresAt:I(de(e,i)),expiresIn:i}}n(ks,"calculateAccessTokenExpiresAt");function df(e){let t=e.claimedResource===void 0?[]:Array.isArray(e.claimedResource)?e.claimedResource:[e.claimedResource];if(e.requestedResource!==void 0){if(t.length>0&&!t.includes(e.requestedResource))throw new m("invalid_target","Token request resource must match the ID-JAG resource.");return e.requestedResource}if(t.length===0)throw new m("invalid_target","resource is required for the ID-JAG JWT bearer grant.");if(t.length!==1)throw new m("invalid_target","ID-JAG resource arrays require a token request resource.");return t[0]}n(df,"readIdJagResource");function uf(e){if(e.claimAuthorizationDetails===void 0)return;let t=(e.grantedAuthorizationDetails??[]).filter(r=>r.locations?.includes(e.resource)===!0);if(t.length===0)throw new m("invalid_grant","ID-JAG authorization_details must authorize the requested resource.");return t}n(uf,"readIdJagGrantedAuthorizationDetails");function lf(e){if(e.claimScope?.split(/\s+/).includes(M)===!0||(e.grantedAuthorizationDetails?.length??0)>0)return M;if(e.claimScope===void 0)throw new m("invalid_grant",`ID-JAG must include ${M} scope or matching authorization_details.`);if(!e.claimScope.split(/\s+/).includes(M))throw new m("invalid_grant",`ID-JAG scope must include ${M}.`);return M}n(lf,"readIdJagGrantedScope");function pf(e){if(e!==void 0&&e.get("dpop")!==null)throw new m("invalid_request","DPoP proofs are not supported for the ID-JAG JWT bearer grant.")}n(pf,"assertNoDpopProofForIdJag");function Ts(e){if(!e?.startsWith("Basic "))return{};let t;try{t=atob(e.slice(6))}catch{throw new m("invalid_client","Malformed HTTP Basic client authentication.")}let r=t.indexOf(":");if(r<0)throw new m("invalid_client","Malformed HTTP Basic client authentication.");try{return{clientId:decodeURIComponent(t.slice(0,r)),clientSecret:decodeURIComponent(t.slice(r+1))}}catch{throw new m("invalid_client","Malformed HTTP Basic client authentication.")}}n(Ts,"readBasicClientSecret");function Us(e){if(e.basicClientId!==void 0&&e.bodyClientId!==void 0&&e.basicClientId!==e.bodyClientId)throw new m("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=Vm(e.clientAssertion);if(typeof r.iss=="string"&&typeof r.sub=="string"&&r.iss===r.sub)return r.iss}catch{throw new m("invalid_client","Malformed private_key_jwt client assertion.")}throw new m("invalid_client","private_key_jwt client assertion must identify the client with matching iss and sub claims.")}throw new m("invalid_client","Client authentication or client_id is required.")}n(Us,"resolveAuthenticatedClientId");function mf(e){if(e.basicClientSecret!==void 0&&e.bodyClientSecret!==void 0)throw new m("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(mf,"resolveClientSecretInput");function ff(e){return e.clientAssertion!==void 0||e.clientAssertionType!==void 0}n(ff,"hasClientAssertion");function hf(e){if(e.requestUrl===void 0)throw new m("invalid_request","Request URL is required for private_key_jwt client authentication.");let t=new URL(H().actionPath(e.pathname),q(e.requestUrl,e.requestHeaders));return t.search="",t.hash="",t.toString()}n(hf,"buildEndpointAudience");function gf(e){return e instanceof Et.JWTExpired?"expired":e instanceof Et.JWTClaimValidationFailed?"claim":e instanceof Et.JWSSignatureVerificationFailed?"signature":e instanceof Et.JWKSNoMatchingKey?"jwks_no_match":e instanceof Et.JWTInvalid?"invalid":e instanceof d.ZodError?"schema":"other"}n(gf,"readJwtFailureKind");async function yf(e){let{response:t,json:r}=await ui(e.jwksUri,{headers:{accept:"application/json"}},{context:e.context,maxRedirects:tf,maxResponseBytes:ef,timeoutMs:Qm});if(!t.ok)throw new m("invalid_client","Client JWKS could not be fetched.");return sf.parse(r)}n(yf,"fetchClientJwks");async function _f(e){if(e.clientAssertionType!==Zt||e.clientAssertion===void 0)throw new m("invalid_request","private_key_jwt client authentication requires a JWT bearer client_assertion and client_assertion_type.");let t=ue.parse(e.clientId),r=await _r(t,e.now);if(r.metadata.token_endpoint_auth_method!=="private_key_jwt")throw new m("invalid_client","Client is not registered for private_key_jwt authentication.");let o=r.metadata.jwks_uri;if(o===void 0)throw new m("invalid_client","Client JWKS URI is required for private_key_jwt authentication.");let i=hf({requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,pathname:e.endpointPathname});try{let a=await yf({jwksUri:o,context:e.context}),{payload:c}=await Ym(e.clientAssertion,Wm(a),{issuer:t,subject:t,audience:i,currentDate:e.now}),s=Math.floor(e.now.getTime()/1e3)+rf;if(typeof c.exp!="number"||c.exp>s)throw new m("invalid_client","Client authentication failed.")}catch(a){throw e.context?.log.warn({event:"oauth_private_key_jwt_client_auth_failed",clientId:t,failureKind:gf(a)},"OAuth private_key_jwt client authentication failed"),new m("invalid_client","Client authentication failed.")}return{method:"private_key_jwt",clientId:t}}n(_f,"verifyPrivateKeyJwtClientAssertion");async function wf(e){let t=ue.parse(e.clientId);if(qo(t))throw new m("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 x(e.clientSecret)}}n(wf,"buildRuntimeHttpClientAuth");async function Ps(e){if(ff({clientAssertion:e.clientAssertion,clientAssertionType:e.clientAssertionType})){if(e.basicClientSecret!==void 0||e.bodyClientSecret!==void 0)throw new m("invalid_request","Use only one client authentication method per request.");return _f(e)}let t=mf({basicClientSecret:e.basicClientSecret,bodyClientSecret:e.bodyClientSecret});return wf({clientId:e.clientId,...t})}n(Ps,"resolveRuntimeHttpClientAuth");async function Es(e){of(e.body);let t=nf.parse(e.body),r=Ts(e.authorizationHeader),o=Us({basicClientId:r.clientId,bodyClientId:t.client_id,clientAssertion:t.client_assertion}),i=new Date,a=await Ps({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 Rf({parsed:t,clientId:o,clientAuth:a,now:i,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,context:e.context})}n(Es,"exchangeDownstreamToken");async function Rf(e){if(e.parsed.grant_type==="authorization_code"){it(e.parsed.redirect_uri,"invalid_request"),at(e.parsed.scope),e.parsed.resource!==void 0&&Me(e.requestUrl??e.parsed.resource,e.parsed.resource,e.requestHeaders);let s=le(),u=le(),p=I(de(e.now,cf())),f=ks(e.now,p),w=await b().exchangeAuthorizationCode({clientAuth:e.clientAuth,codeHash:await x(e.parsed.code),redirectUri:e.parsed.redirect_uri,resource:e.parsed.resource,codeChallenge:await Yt(e.parsed.code_verifier),currentRefreshTokenHash:await x(s),accessTokenHash:await x(u),grantExpiresAt:p,accessTokenExpiresAt:f.expiresAt,now:I(e.now)});if(w.kind==="invalid_client")throw new m("invalid_client","Client authentication failed.");if(w.kind==="resource_mismatch")throw new m("invalid_target","Token request resource must match the authorization code resource.");if(w.kind!=="exchanged")throw new m("invalid_grant","Authorization code is invalid, expired, already used, or failed binding validation.");return e.context&&v(e.context,{eventType:S.MCP_OAUTH_TOKEN_ISSUED,outcome:"success",attributes:{clientId:e.clientId,grantType:"authorization_code"}}),{access_token:u,token_type:"Bearer",expires_in:f.expiresIn,refresh_token:s,scope:w.grant.scope,resource:w.grant.resource}}if(e.parsed.grant_type===be){at(e.parsed.scope),pf(e.requestHeaders);let s=await As({assertion:e.parsed.assertion,authenticatedClientId:e.clientId,clientAuth:e.clientAuth,requestUrl:e.requestUrl??e.parsed.resource??"",requestHeaders:e.requestHeaders,requestedResource:e.parsed.resource,now:e.now,context:e.context,config:L()}),u=df({claimedResource:s.claims.resource,requestedResource:e.parsed.resource}),p=Me(e.requestUrl??u,u,e.requestHeaders),f=uf({claimAuthorizationDetails:s.claims.authorization_details,grantedAuthorizationDetails:s.grantedAuthorizationDetails,resource:u}),w=lf({claimScope:s.claims.scope,grantedAuthorizationDetails:f}),U=le(),y=I(new Date(s.claims.exp*1e3)),P=ks(e.now,y),k=await b().issueAccessTokenForIdJag({clientAuth:e.clientAuth,accessTokenHash:await x(U),subjectId:s.subjectId,resource:u,operationId:p.operationId,scope:w,authorizationDetails:f,accessTokenExpiresAt:P.expiresAt,now:I(e.now),idJag:{issuer:s.claims.iss,jti:s.claims.jti,tenant:s.claims.tenant,expiresAt:y}});if(k.kind==="invalid_client")throw new m("invalid_client","Client authentication failed.");if(k.kind==="resource_mismatch")throw new m("invalid_target","Token request resource must match the ID-JAG resource.");return e.context&&v(e.context,{eventType:S.MCP_OAUTH_TOKEN_ISSUED,outcome:"success",attributes:{clientId:e.clientId,grantType:"jwt-bearer"}}),{access_token:U,token_type:"Bearer",expires_in:P.expiresIn,scope:k.grant.scope,resource:k.grant.resource,...f===void 0?{}:{authorization_details:f}}}at(e.parsed.scope),e.parsed.resource!==void 0&&Me(e.requestUrl??e.parsed.resource,e.parsed.resource,e.requestHeaders);let t=await x(e.parsed.refresh_token),r=e.parsed.refresh_token,o=le(),i=I(de(e.now,xs())),a=await b().refreshToken({clientAuth:e.clientAuth,currentRefreshTokenHash:t,nextRefreshTokenHash:t,accessTokenHash:await x(o),resource:e.parsed.resource,accessTokenExpiresAt:i,now:I(e.now)});if(a.kind==="invalid_client")throw new m("invalid_client","Client authentication failed.");if(a.kind==="resource_mismatch")throw new m("invalid_target","Token request resource must match the refresh token grant resource.");if(a.kind!=="rotated")throw new m("invalid_grant","Refresh token is invalid, expired, or revoked.");Me(e.requestUrl??a.grant.resource,a.grant.resource,e.requestHeaders);let c=a.accessToken.expiresAt;return e.context&&v(e.context,{eventType:S.MCP_OAUTH_TOKEN_ISSUED,outcome:"success",attributes:{clientId:e.clientId,grantType:"refresh_token"}}),{access_token:o,token_type:"Bearer",expires_in:Math.max(1,Math.floor((new Date(c).getTime()-e.now.getTime())/1e3)),refresh_token:r,scope:a.grant.scope,resource:a.grant.resource}}n(Rf,"exchangeDownstreamTokenWithRuntimeHttp");async function Os(e){let t=af.parse(e.body),r=Ts(e.authorizationHeader),o=Us({basicClientId:r.clientId,bodyClientId:t.client_id,clientAssertion:t.client_assertion}),i=new Date;if((await b().revokeOAuthToken({clientAuth:await Ps({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 x(t.token),now:I(i)})).kind==="invalid_client")throw new m("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:S.MCP_OAUTH_TOKEN_REVOKED,outcome:"success",attributes:{clientId:o,...t.token_type_hint===void 0?{}:{tokenTypeHint:t.token_type_hint}}})}n(Os,"revokeDownstreamToken");var bf=64*1024,If=16*1024,Sf="text/html; charset=utf-8";function Cf(e){let t={};for(let[r,o]of e.entries())t[r]=o;return t}n(Cf,"formDataToObject");async function vf(e){return ga(e,{maxBytes:bf,label:"Request body"})}n(vf,"readJsonBody");async function Un(e){return Cf(await ya(e,{maxBytes:If,label:"Request body"}))}n(Un,"readFormBody");async function Ms(e,t,r){let o=ce(r),i=r instanceof d.ZodError?ke(r):void 0,a={code:o??(r instanceof d.ZodError?"invalid_request":"internal_server_error")};return i!==void 0&&(a.detail=i),Lt(e,t,a)}n(Ms,"handleProblem");function Ds(e){return e?.requestId}n(Ds,"readBrowserRequestId");function js(e){if(!(e instanceof h))return;let t=e.extensionMembers?.[Ne];return typeof t=="string"?t:void 0}n(js,"readUpstreamHtmlError");function qs(e,t){let r=e.extensionMembers?.[t];return typeof r=="string"?r:void 0}n(qs,"readRuntimeErrorExtensionString");function Af(e,t){let r=e.extensionMembers?.[t];return typeof r=="number"?r:void 0}n(Af,"readRuntimeErrorExtensionNumber");function kf(e){try{return new URL(e.url).pathname}catch{return}}n(kf,"readBrowserRequestPath");function De(e){let t={code:e.code,requestId:e.requestId,routePath:kf(e.request),underlyingError:e.underlyingError};return e.error instanceof h&&(t.httpStatus=Af(e.error,_e),t.contentType=qs(e.error,Le),t.upstreamUrl=qs(e.error,we)),t}n(De,"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 xf(e,t){return e.errorCode!=="invalid_client"?{}:t.includeInvalidClientChallenge===!1?{}:{"WWW-Authenticate":'Basic realm="OAuth"'}}n(xf,"readOAuthProtocolHeaders");function Tf(e,t){let r=ne("internal_server_error");return Ot({error:e.errorCode,errorDescription:e.errorCode==="server_error"?r.publicDetail:e.message,status:e.status,headers:xf(e,t)})}n(Tf,"oauthProtocolErrorResponse");function Tn(e){return e.issues[0]?.path.includes("resource")===!0?"invalid_target":"invalid_request"}n(Tn,"readZodOAuthErrorCode");function Uf(e){let t={error:Tn(e)},r=ke(e);return r!==void 0&&(t.errorDescription=r),Ot(t)}n(Uf,"oauthZodErrorResponse");function Pf(e){let t=ce(e);if(t===void 0)return;let r=ne(t);if(r.oauthError===void 0)return;let o={error:r.oauthError,status:Of(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(Pf,"oauthGatewayProblemResponse");function Ef(){let t={error:"server_error",status:500,errorDescription:ne("internal_server_error").publicDetail};return Ot(t)}n(Ef,"oauthFallbackErrorResponse");function Of(e){switch(e){case"invalid_client":return 401;case"server_error":return 500;default:return 400}}n(Of,"readOAuthStatus");function Pn(e,t={}){return e instanceof Ae?Bs(e):e instanceof m?Tf(e,t):e instanceof d.ZodError?Uf(e):Pf(e)??Ef()}n(Pn,"oauthProblemResponse");function En(e,t,r){let o=nt(e.url),i=Ds(t);if(r instanceof Ae)return Bs(r);if(r instanceof m){let s=ne("internal_server_error");return ae({host:o,kind:qf(r.errorCode),title:"Authorization failed",detail:r.errorCode==="server_error"?s.publicDetail:r.message,developerDetail:r.errorCode==="server_error"?s.publicDetail:r.message,code:r.errorCode,diagnostic:De({request:e,requestId:i,code:r.errorCode,underlyingError:r.errorCode==="server_error"?s.publicDetail:r.message,error:r}),requestId:i,status:r.status})}if(r instanceof d.ZodError)return ae({host:o,kind:"invalid_request",detail:ke(r)??"The authorization request was invalid.",developerDetail:ke(r)??"The authorization request was invalid.",code:Tn(r),diagnostic:De({request:e,requestId:i,code:Tn(r),underlyingError:ke(r)??"The authorization request was invalid.",error:r}),requestId:i});let a=ce(r);if(a!==void 0){let s=ne(a);return ae({host:o,kind:Hs(a),detail:s.publicDetail,developerDetail:s.status>=500||!(r instanceof Error)?s.publicDetail:r.message,code:a,diagnostic:De({request:e,requestId:i,code:a,underlyingError:s.status>=500||!(r instanceof Error)?s.publicDetail:r.message,error:r}),requestId:i,upstreamHtml:js(r),status:s.status})}let c=ne("internal_server_error");return ae({host:o,kind:"internal_error",detail:c.publicDetail,developerDetail:c.publicDetail,code:"server_error",diagnostic:De({request:e,requestId:i,code:"server_error",underlyingError:c.publicDetail,error:r}),requestId:i,status:c.status})}n(En,"browserOAuthProblemResponse");function zs(e,t,r){let o=nt(e.url),i=Ds(t),a=ce(r);if(a!==void 0){let s=ne(a);return ae({host:o,kind:Hs(a),detail:s.publicDetail,developerDetail:s.status>=500||!(r instanceof Error)?s.publicDetail:r.message,code:a,diagnostic:De({request:e,requestId:i,code:a,underlyingError:s.status>=500||!(r instanceof Error)?s.publicDetail:r.message,error:r}),requestId:i,upstreamHtml:js(r),status:s.status})}if(r instanceof d.ZodError)return ae({host:o,kind:"invalid_request",detail:ke(r)??"The authorization request was invalid.",developerDetail:ke(r)??"The authorization request was invalid.",code:"invalid_request",diagnostic:De({request:e,requestId:i,code:"invalid_request",underlyingError:ke(r)??"The authorization request was invalid.",error:r}),requestId:i});let c=ne("internal_server_error");return ae({host:o,kind:"internal_error",detail:c.publicDetail,developerDetail:c.publicDetail,code:"internal_server_error",diagnostic:De({request:e,requestId:i,code:"internal_server_error",underlyingError:c.publicDetail,error:r}),requestId:i,status:c.status})}n(zs,"browserGatewayProblemResponse");function qf(e){return e==="server_error"?"internal_error":"invalid_request"}n(qf,"readOAuthBrowserErrorKind");function Hs(e){if(ne(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(Hs,"readGatewayBrowserErrorKind");function he(e,t,r){let o={event:t},i=!1;if(r instanceof m)o.oauthError=r.errorCode,o.status=r.status,N(o,"error",r);else if(r instanceof Ae)o.oauthError=r.errorCode,N(o,"error",r);else if(r instanceof d.ZodError){o.code="invalid_request",N(o,"error",r);let a=r.issues[0];a&&(o.zodPath=a.path.join("."))}else{let a=ce(r);if(a!==void 0){let c=ne(a);o.code=a,o.status=c.status,c.oauthError!==void 0&&(o.oauthError=c.oauthError),i=c.status>=500||c.oauthError==="server_error",N(o,"error",r)}else i=!0,N(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(he,"logUnexpectedOAuthHandlerError");function Bs(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(Bs,"downstreamAuthorizeRedirectErrorResponse");function ke(e){let t=e.issues[0];if(!t)return;let r=t.path.join(".");return r?`${r}: ${t.message}`:t.message}n(ke,"formatZodErrorDetail");function Mf(e,t){let r={event:"browser_login_callback_failed",code:ce(t)??"invalid_request"};N(r,"error",t),e.log.warn(r,"Browser login callback failed; client received a connection-failure page")}n(Mf,"logBrowserLoginCallbackFailure");function Ls(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(Ls,"redirectResultResponse");function Rr(e){if(e.kind==="setup_page"){let t=new Headers({"content-type":Sf,"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 Ls(e)}n(Rr,"authorizeResultResponse");async function Ns(e,t){try{return Response.json(Co(e.url,e.headers))}catch(r){return he(t,"oauth_authorization_server_metadata_failed",r),Ms(e,t,r)}}n(Ns,"authorizationServerMetadataHandler");async function Js(e,t){try{let r=Or(e.params.routePath);return Response.json(vo({operationId:r.operationId,requestUrl:e.url,requestHeaders:e.headers}))}catch(r){return he(t,"oauth_authorization_server_metadata_failed",r),Ms(e,t,r)}}n(Js,"scopedAuthorizationServerMetadataHandler");async function Gs(e,t){try{let r=await Va(await vf(e)),o=r.client_id,i=r.client_name,a=r.redirect_uris.length,c=r.token_endpoint_auth_method;return t.log.info({event:"oauth_dcr_client_registered",clientId:o,clientName:i,redirectUriCount:a,tokenEndpointAuthMethod:c},"OAuth Dynamic Client Registration completed"),v(t,{eventType:S.MCP_OAUTH_CLIENT_REGISTERED,outcome:"success",clientName:i,attributes:{clientId:o,redirectUriCount:a,tokenEndpointAuthMethod:c}}),Response.json(r,{status:201,headers:{"cache-control":"no-store"}})}catch(r){return he(t,"oauth_register_failed",r),Pn(r)}}n(Gs,"registerHandler");async function Fs(e,t){try{return Rr(await kn(e,{context:t}))}catch(r){return he(t,"oauth_authorize_failed",r),En(e,t,r)}}n(Fs,"authorizeHandler");async function $s(e,t){try{let r=Or(e.params.routePath);return Rr(await kn(e,{operationId:r.operationId,context:t}))}catch(r){return he(t,"oauth_authorize_scoped_failed",r),En(e,t,r)}}n($s,"scopedAuthorizeHandler");async function Zs(e,t){try{let r=await _s(e,{context:t});return t.log.info({event:"browser_login_callback_completed",resultKind:r.kind},"Browser login callback completed; consent setup rendered"),Rr(r)}catch(r){return Mf(t,r),zs(e,t,r)}}n(Zs,"callbackHandler");async function Ks(e,t){try{return Ls(await ws(e))}catch(r){return he(t,"oauth_dev_login_failed",r),En(e,t,r)}}n(Ks,"devLoginHandler");async function Ws(e,t){try{if(!["GET","POST"].includes(e.method))return new Response(null,{status:405,headers:{allow:"GET, POST"}});let r=await Rs({request:e,body:e.method==="POST"?await Un(e):void 0,context:t});return Rr(r)}catch(r){return he(t,"oauth_setup_failed",r),zs(e,t,r)}}n(Ws,"setupHandler");async function Vs(e,t){try{return Response.json(await Es({body:await Un(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 he(t,"oauth_token_failed",r),Pn(r)}}n(Vs,"tokenHandler");async function Ys(e,t){try{return await Os({body:await Un(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 he(t,"oauth_revoke_failed",r),Pn(r)}}n(Ys,"revokeHandler");function Xs(e){return C`<p data-gateway-error-code="${e.code}">${e.body}</p>`}n(Xs,"renderBrowserResult");var Df="text/html; charset=utf-8",jf="none";function zf(e){let t=Kr(e.host);return rt({title:e.title,iconHref:t,styles:tt,headerIcon:wr({iconHref:t,fallbackIconHref:nr}),heading:e.title,subhead:"",body:Xs({body:e.body,code:e.code??jf}),footer:""})}n(zf,"browserResultHtml");function Hf(e,t=200){return new Response(et(e),{status:t,headers:{"content-type":Df,"cache-control":"no-store","referrer-policy":"no-referrer","x-frame-options":"DENY"}})}n(Hf,"browserResultResponse");function Qs(e){return Hf(zf(e))}n(Qs,"browserConnectionSuccessResponse");function br(e,t,r={}){let o=ro(t);return ae({host:e,kind:Bf(t),detail:o.body,developerDetail:r.developerDetail,code:t,diagnostic:r.diagnostic,upstreamHtml:r.upstreamHtml})}n(br,"browserConnectionFailureResponse");function Bf(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(Bf,"readCallbackFailureBrowserErrorKind");var Lf={connect:"Connect",callback_authorization_code:"Callback",callback_provider_error:"Callback",callback_invalid:"Callback",client_metadata:"Client metadata"},ec=Symbol("upstream-request");function qt(e,t){Object.defineProperty(e,ec,{configurable:!0,value:t})}n(qt,"setUpstreamRequestContext");function Nf(e){let t=e[ec];if(!t)throw new ee("Upstream request context has not been set");return t}n(Nf,"readUpstreamRequestContext");function Jf(e,t){return t.some(r=>r===e)}n(Jf,"requestContextMatchesKind");function Gf(e){return typeof e=="string"?[e]:e}n(Gf,"toExpectedKinds");function Mt(e,t){let r=Nf(e),o=Gf(t);if(!Jf(r.kind,o)){let i=Lf[o[0]];throw new ee(`${i} request context has not been set`)}return r}n(Mt,"requireUpstreamRequestContext");function je(e){if(typeof e=="string"&&e.length!==0)return e}n(je,"readOptionalQueryString");function Ff(e,t){let r=e.params[t];if(typeof r!="string"||r.length===0)throw new ee(`Validated path parameter ${t} is missing`);return $f(r,t)}n(Ff,"requirePathString");function $f(e,t){try{return decodeURIComponent(e)}catch(r){throw new h({message:`Path parameter "${t}" must be valid URL encoding.`,extensionMembers:{[g]:"invalid_request"}},{cause:r})}}n($f,"decodePathString");function Zf(e){let t=je(e);return t?Nt.parse(t):void 0}n(Zf,"readOptionalOperationId");function Kf(e){let t=te().connectionsById.get(e);if(t!==void 0)return t.authProfileId;throw new h({message:`No upstream connection is registered for ${e}.`,extensionMembers:{[g]:"unknown_upstream_server"}})}n(Kf,"readRegisteredAuthProfileId");function Wf(e){let t=Zf(e);if(!t)throw new h({message:"operationId query parameter is required.",extensionMembers:{[g]:"invalid_request"}});return t}n(Wf,"readRequiredOperationId");async function Vf(e,t){let r=pr(t,Wf(e.query.operationId));if(r.authMode==="id-jag")throw new h({message:"This upstream uses XAA / ID-JAG and does not support browser OAuth connection flows.",extensionMembers:{[g]:"invalid_request"}});let o=e.query.redirect==="true",i=je(e.query.browserTicket);if(e.user){if(i)throw new h({message:"Use either an authenticated gateway request or a browser connect ticket, not both.",extensionMembers:{[g]:"invalid_request"}});let s=Te(e.user,e.url),u={kind:"connect",...Qe(r,s.subjectId),redirect:o},p=uo(je(e.query.returnTo));return p!==void 0&&(u.returnTo=p),u}if(!i)throw new h({message:"Authentication is required to start the upstream connection flow.",extensionMembers:{[g]:"authentication_required"}});let a=await Ai(i);if(a.ownerMode!==r.ownerMode||a.upstreamServerId!==r.upstreamServerId||a.authProfileId!==r.authProfileId||a.operationId!==r.operationId)throw new h({message:"Browser connect ticket did not match the requested upstream flow",extensionMembers:{[g]:"oauth_callback_mismatch"}});await ki(a);let c=Ft(a);switch(r.authMode){case"shared-oauth":{if(c.mode!=="shared")throw new h({message:"Browser connect ticket did not match the requested upstream flow",extensionMembers:{[g]:"oauth_callback_mismatch"}});let s={kind:"connect",...r,authMode:"shared-oauth",ownerMode:"shared",owner:c,initiatedBySubjectId:a.initiatedBySubjectId,redirect:o};return a.returnTo!==void 0&&(s.returnTo=a.returnTo),s}case"user-oauth":{if(c.mode!=="user")throw new h({message:"Browser connect ticket did not match the requested upstream flow",extensionMembers:{[g]:"oauth_callback_mismatch"}});let s={kind:"connect",...r,authMode:"user-oauth",ownerMode:"user",owner:c,initiatedBySubjectId:a.initiatedBySubjectId,redirect:o};return a.returnTo!==void 0&&(s.returnTo=a.returnTo),s}}}n(Vf,"resolveConnectContext");async function Yf(e,t,r){let o=io.parse(Ff(e,"connection"));switch(r){case"connect":qt(e,await Vf(e,o));return;case"callback":{let i=je(e.query.error);if(i){let s={kind:"callback_provider_error",upstreamServerId:o,error:i},u=je(e.query.error_description);u!==void 0&&(s.errorDescription=u),qt(e,s);return}let a=je(e.query.code),c=je(e.query.state);if(a&&c){qt(e,{kind:"callback_authorization_code",upstreamServerId:o,code:a,state:c});return}qt(e,{kind:"callback_invalid",upstreamServerId:o});return}case"client_metadata":qt(e,{kind:"client_metadata",upstreamServerId:o,authProfileId:Kf(o)});return}}n(Yf,"resolveUpstreamRequestInbound");async function Xf(e,t,r){try{await Yf(e,t,r);return}catch(o){let i=o instanceof h?o.extensionMembers?.[g]:void 0,a=o instanceof Error?o.message:void 0;switch(i){case"invalid_request":case"unknown_upstream_server":case"oauth_callback_mismatch":return xe.badRequest(e,t,{code:i,detail:a});case"authentication_required":return xe.unauthorized(e,t,{code:i,detail:a});default:throw o}}}n(Xf,"applyUpstreamRequestContext");function Ir(e,t){return n(async(o,i)=>{let a=await Xf(o,i,e);return a||t(o,i)},"wrapped")}n(Ir,"withUpstreamRequestContext");var Qf=["callback_authorization_code","callback_provider_error","callback_invalid"];function On(e){try{return new URL(e.url).pathname}catch{return}}n(On,"readBrowserRequestPath");function eh(e){return"cause"in e?e.cause:void 0}n(eh,"readErrorCause");function th(e){return e.stack?.split(`
49
- `).slice(1,4).map(t=>t.trim()).join(" | ")}n(th,"readFirstStackFrame");function tc(e,t,r){r instanceof Error&&(e[`${t}Name`]=r.name,e[`${t}Message`]=r.message,e[`${t}StackFrame`]=th(r))}n(tc,"addErrorAttributes");function qn(e){if(!(e instanceof h))return;let t=e.extensionMembers?.[g];return Bt(t)?t:void 0}n(qn,"readRuntimeGatewayCode");function rc(e,t){let r=e.extensionMembers?.[t];return typeof r=="string"?r:void 0}n(rc,"readRuntimeErrorExtensionString");function rh(e,t){let r=e.extensionMembers?.[t];return typeof r=="number"?r:void 0}n(rh,"readRuntimeErrorExtensionNumber");function nh(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:S.MCP_AUTH_UPSTREAM_TOKEN_EXCHANGE_FAILED,outcome:"failure",upstreamServerName:r.upstreamServerId,reasonCode:"provider_access_denied",reasonClass:"auth",attributes:{error:r.error,errorDescription:r.errorDescription}}),br(o,"provider_access_denied",{developerDetail:r.errorDescription??r.error,diagnostic:{code:"provider_access_denied",requestId:t.requestId,routePath:On(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"),br(o,"oauth_state_invalid",{diagnostic:{code:"oauth_state_invalid",requestId:t.requestId,routePath:On(e),upstreamServerId:r.upstreamServerId}});case"callback_authorization_code":return r}}n(nh,"requireAuthorizationCallbackRequest");function oh(e,t){v(e,{eventType:S.MCP_AUTH_UPSTREAM_CALLBACK_RECEIVED,outcome:"success",upstreamServerName:t.upstreamServerId})}n(oh,"emitCallbackReceivedAnalyticsEvent");function ih(e,t){v(e,{eventType:S.MCP_AUTH_UPSTREAM_TOKEN_EXCHANGE_SUCCEEDED,outcome:"success",upstreamServerName:t.upstreamServerId,virtualServerName:t.operationId})}n(ih,"emitTokenExchangeSucceededAnalyticsEvent");function ah(e,t){if(t.returnTo){let r=t.returnOrigin??e.url;return Response.redirect(new URL(t.returnTo,r).toString(),302)}return Qs({host:nt(e.url),title:"Connection complete",body:"The upstream authorization flow completed successfully. You can return to your MCP client."})}n(ah,"buildSuccessfulCallbackResponse");function sh(e){let t={detail:e instanceof Error?e.message:void 0};return tc(t,"error",e),e instanceof Error&&tc(t,"cause",eh(e)),t}n(sh,"buildTokenExchangeFailureAttributes");function ch(e){v(e.context,{eventType:S.MCP_AUTH_UPSTREAM_TOKEN_EXCHANGE_FAILED,outcome:"failure",upstreamServerName:e.callbackRequest.upstreamServerId,reasonCode:qn(e.error)??"token_exchange_failed",reasonClass:"auth",errorType:e.error instanceof Error?e.error.name:"unknown",attributes:sh(e.error)})}n(ch,"emitTokenExchangeFailedAnalyticsEvent");function dh(e){let t=e.error,r=qn(t),o=to(r)?r:"upstream_token_exchange_failed",i={code:o,requestId:e.context.requestId,routePath:On(e.request),upstreamServerId:e.callbackRequest.upstreamServerId,underlyingError:t instanceof Error?t.message:void 0,...t instanceof h?{httpStatus:rh(t,_e),contentType:rc(t,Le),upstreamUrl:rc(t,we)}:{}};return br(e.host,o,{developerDetail:t instanceof Error?t.message:void 0,diagnostic:i,upstreamHtml:uh(t)})}n(dh,"tokenExchangeFailureResponse");function uh(e){if(!(e instanceof h))return;let t=e.extensionMembers?.[Ne];return typeof t=="string"?t:void 0}n(uh,"readUpstreamHtmlError");async function Mn(e,t){let r=Mt(e,Qf),o=nt(e.url),i=nh(e,t,r,o);if(i instanceof Response)return i;oh(t,i);try{let a=await aa({request:e,callbackRequest:i});return ih(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"),ah(e,a)}catch(a){let c={event:"upstream_oauth_token_exchange_failed",code:qn(a)??"upstream_token_exchange_failed",upstreamServerId:i.upstreamServerId};return N(c,"error",a),t.log.warn(c,"Upstream OAuth token exchange failed; user shown connection-failure page"),ch({context:t,callbackRequest:i,error:a}),dh({request:e,context:t,host:o,callbackRequest:i,error:a})}}n(Mn,"callbackHandler");function lh(e){return(e instanceof Error?e.message:void 0)??"The requested upstream client metadata document was not found."}n(lh,"clientMetadataProblemDetail");async function nc(e,t){let r=Mt(e,"connect"),o=await ia({request:e,connectRequest:r});if(v(t,{eventType:S.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 dr({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(nc,"connectHandler");async function oc(e,t){let r=Mt(e,"client_metadata");try{let o=q(e.url,e.headers),i=Mi(o,r.upstreamServerId,r.authProfileId);return Response.json(i)}catch(o){if(!(o instanceof B))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"),xe.notFound(e,t,{code:"not_found",detail:lh(o)})}}n(oc,"oauthClientMetadataHandler");function ph(e,t){return e.mount==="root"?e.path:t.actionPath(e.path)}n(ph,"resolveInternalRoutePath");var mh={"access-control-allow-origin":"*","access-control-allow-methods":"GET, OPTIONS","access-control-allow-headers":"content-type, authorization","access-control-max-age":"86400"};function fh(){return new Response(null,{status:204,headers:mh})}n(fh,"buildWellKnownPreflightResponse");function hh(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(hh,"withWellKnownCorsHeaders");function Dn(e){return async(t,r)=>t.method==="OPTIONS"?fh():hh(await e(t,r))}n(Dn,"wrapWellKnownHandler");var sc=[{routeName:"oauth_as_metadata",mount:"root",path:"/.well-known/oauth-authorization-server",methods:["GET","OPTIONS"],handler:Dn(Ns),corsPolicy:"anything-goes"},{routeName:"oauth_as_metadata_scoped",mount:"root",path:"/.well-known/oauth-authorization-server/:routePath*",methods:["GET","OPTIONS"],handler:Dn(Js),corsPolicy:"anything-goes"},{routeName:"oauth_protected_resource_metadata",mount:"root",path:"/.well-known/oauth-protected-resource/:routePath*",methods:["GET","OPTIONS"],handler:Dn(Ao),corsPolicy:"anything-goes"},{routeName:"oauth_register",mount:"action",path:"/oauth/register",methods:["POST"],handler:Gs},{routeName:"oauth_authorize",mount:"action",path:"/oauth/authorize",methods:["GET"],handler:Fs},{routeName:"oauth_authorize_scoped",mount:"action",path:"/oauth/authorize/:routePath*",methods:["GET"],handler:$s},{routeName:"oauth_callback",mount:"action",path:"/oauth/callback",methods:["GET"],handler:Zs},{routeName:"oauth_dev_login",mount:"action",path:"/oauth/dev-login",methods:["GET"],handler:Ks},{routeName:"oauth_setup",mount:"action",path:"/oauth/setup",methods:["GET","POST"],handler:Ws},{routeName:"oauth_token",mount:"action",path:"/oauth/token",methods:["POST"],handler:Vs},{routeName:"oauth_revoke",mount:"action",path:"/oauth/revoke",methods:["POST"],handler:Ys},{routeName:"upstream_client_metadata",mount:"action",path:"/.well-known/oauth-client/:connection",methods:["GET"],handler:Ir("client_metadata",oc)},{routeName:"upstream_connect",mount:"action",path:"/auth/connections/:connection/connect",methods:["GET"],handler:Ir("connect",nc)},{routeName:"upstream_callback",mount:"action",path:"/auth/connections/:connection/callback",methods:["GET"],handler:Ir("callback",Mn)}],gh=sc.filter(e=>!e.routeName.startsWith("upstream_")),yh=sc.filter(e=>e.routeName.startsWith("upstream_"));function _h(e){let t=ho({routes:e.routes,policies:e.policies,gateway:e.gateway});return go(t),t}n(_h,"initializeMcpGatewayConnectionRegistry");function wh(e){return[...e.byOperationId.values()].some(t=>t.downstreamOAuth!==void 0)}n(wh,"hasDownstreamOAuthRoutes");function Rh(e){return[...e.byOperationId.values()].some(t=>t.downstreamOAuth?.config.idJag.enabled===!0)}n(Rh,"hasIdJagDownstreamOAuth");function bh(e){let t=new Map;for(let o of e.byOperationId.values())o.downstreamOAuth&&t.set(o.downstreamOAuth.policyName,o.downstreamOAuth.config);if(t.size===1)return[...t.values()][0];let r=[...t.keys()].map(o=>`"${o}"`).join(", ");throw new B(`MCP gateway found multiple attached OAuth policies: ${r}. Multiple downstream MCP OAuth configs in one gateway are not supported yet; use one MCP OAuth policy across MCP routes or split these routes into separate gateways.`)}n(bh,"readSingletonDownstreamOAuthConfig");function Ih(e,t,r){let o=String(t.params.routePath??""),i=e.byRoutePath.get(bo(o));if(i===void 0)return;let a=i?.downstreamOAuth?.config;return a===void 0?Lt(t,r,{code:"not_found",detail:"The requested MCP route does not expose downstream OAuth."}):a}n(Ih,"readScopedDownstreamOAuthConfig");function Sh(e){return e.path==="/.well-known/oauth-authorization-server/:routePath*"||e.path==="/.well-known/oauth-protected-resource/:routePath*"||e.path==="/oauth/authorize/:routePath*"}n(Sh,"routeUsesScopedOAuthConfig");function ic(e,t,r){return async(o,i)=>{if(i.log.setLogProperties?.({requestId:i.requestId}),r){let u=await r(o,i);if(u instanceof Response)return u;u&&Xn(i,u)}let a=o.method==="OPTIONS",c=Date.now();a||i.log.info({event:`${e}_received`,method:o.method},`MCP gateway: ${e} received`);let s=await t(o,i);return a||i.log.info({event:`${e}_responded`,status:s.status,durationMs:Date.now()-c},`MCP gateway: ${e} responded`),s}}n(ic,"wrapInternalHandler");function ac(e,t,r,o){e.addPluginRoute({path:ph(t,r),methods:t.methods,handler:o,processors:[Nn],corsPolicy:t.corsPolicy??"none"})}n(ac,"addInternalRoute");function cc(e,t){let r=_h(t),o=wh(r),i=r.connectionsById.size>0,a,c=n(()=>(a===void 0&&(a=bh(r)),a),"readSingletonOAuthConfig");if(o){Z("plugin.mcp-gateway.downstream-oauth"),Rh(r)&&Z("plugin.mcp-gateway.downstream-oauth.id-jag");for(let s of gh){let u=Sh(s)?(p,f)=>Ih(r,p,f):c;ac(e,s,r.gateway,ic(s.routeName,s.handler,u))}}if(i){Z("plugin.mcp-gateway.upstream-auth");for(let s of r.connectionsById.values())Z(`plugin.mcp-gateway.upstream-auth.${s.authMode}`);for(let s of yh)ac(e,s,r.gateway,ic(s.routeName,s.handler))}}n(cc,"registerMcpGatewayInternalRoutes");var jn=class extends Bn{static{n(this,"McpGatewayPlugin")}#e;constructor(t={}){super(),Z("plugin.mcp-gateway"),this.#e=Qn(t)}registerRoutes(t){let r=t.parsedRouteData;r&&cc(t.router,{routes:r.routes,policies:r.policies,gateway:this.#e})}};var Ch=new TextDecoder;function vh(e){if(e)try{return JSON.parse(Ch.decode(e))}catch{return}}n(vh,"readBodyJson");function ge(e){return e&&typeof e=="object"?e:void 0}n(ge,"readRecord");function Dt(e,t){let r=ge(e)?.[t];return typeof r=="string"?r:void 0}n(Dt,"readStringProperty");function uc(e,t){let r=ge(e)?.[t];return typeof r=="number"?r:void 0}n(uc,"readNumberProperty");function dc(e,t){return uc(e,"code")??(t.status>=400?t.status:void 0)}n(dc,"readErrorCode");function lc(e){return Array.isArray(e)?e.map(lc).find(t=>t?.method):ge(e)}n(lc,"readJsonRpcMessage");function pc(e){let t=lc(vh(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:Dt(o,"name")};case"prompts/list":return{mcpMethod:r,capabilityType:"prompt"};case"prompts/get":return{mcpMethod:r,capabilityType:"prompt",capabilityName:Dt(o,"name")};case"resources/list":case"resources/templates/list":return{mcpMethod:r,capabilityType:"resource"};case"resources/read":{let i=Dt(o,"uri");return{mcpMethod:r,capabilityType:"resource",capabilityName:i,resourceUri:i}}default:return null}}n(pc,"buildBaseCapabilityInput");function mc(e){return e==="tools/list"||e==="prompts/list"||e==="resources/list"||e==="resources/templates/list"}n(mc,"isCapabilityListMethod");function Ah(e,t,r){let a=ge(r)?.[e==="resources/templates/list"?"resourceTemplates":t==="tool"?"tools":t==="prompt"?"prompts":"resources"];return Array.isArray(a)?a.length:void 0}n(Ah,"readItemCount");async function kh(e){try{return await e.clone().json()}catch{return}}n(kh,"readResponseJson");function fc(e){let t=pc(e);return!t||mc(t.mcpMethod)?null:{eventType:S.MCP_CAPABILITY_INVOKED,outcome:"success",...t}}n(fc,"buildCapabilityInvokedAnalyticsInput");async function hc(e,t){let r=pc(e);if(!r)return null;let o=ge(await kh(t)),i=ge(o?.error),a=ge(i?.data),c=o?.result,s=r.mcpMethod==="tools/call"&&ge(c)?.isError===!0;if(ge(a?.connectRequired))return{eventType:S.MCP_CAPABILITY_CONNECT_REQUIRED,outcome:"connect_required",...r,httpStatusCode:t.status,reasonCode:"connect_required",reasonClass:"auth",errorType:"connect_required",errorCode:uc(i,"code"),mcpErrorType:Dt(i,"message")};if(mc(r.mcpMethod)){let u=t.status>=400?void 0:Ah(r.mcpMethod,r.capabilityType,c);return{eventType:S.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:dc(i,t)}:{},...u===void 0?{}:{attributes:{itemCount:u}}}}return t.status>=400||i?{eventType:S.MCP_CAPABILITY_FAILED,outcome:"failure",...r,httpStatusCode:t.status,reasonCode:"upstream_capability_invocation_failed",reasonClass:"upstream",errorType:"capability_error",errorCode:dc(i,t),mcpErrorType:Dt(i,"message")}:{eventType:S.MCP_CAPABILITY_COMPLETED,outcome:s?"application_error":"success",...r,httpStatusCode:t.status,toolResultIsError:s,applicationError:s}}n(hc,"buildCapabilityFinalAnalyticsInput");var xh={Allow:"POST"};async function Th(e){try{return await e.clone().arrayBuffer()}catch{return}}n(Th,"readRequestBody");function gc(e){try{let t=yo(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(gc,"readRouteAnalyticsFields");function yc(e){return To(e.user,e.url,e.headers)?.subjectId}n(yc,"readRequestSubjectId");function Uh(e){let t=fc(e.requestBody);t&&v(e.context,{...t,...gc(e.context),httpMethod:e.request.method,subjectId:yc(e.request),transport:"http"})}n(Uh,"emitCapabilityInvokedAnalytics");async function Ph(e){let t=await hc(e.requestBody,e.response);t&&v(e.context,{...t,...gc(e.context),httpMethod:e.request.method,subjectId:yc(e.request),transport:"http",latencyMs:Date.now()-e.startedAt})}n(Ph,"emitCapabilityFinalAnalytics");async function Eh(e,t){if(Z("handler.mcp-gateway-proxy"),e.method==="GET")return xe.methodNotAllowed(e,t,{detail:"MCP Gateway routes support stateless Streamable HTTP requests over POST. Server-sent event GET streams are not supported."},xh);let r=Date.now(),o=await Th(e);Uh({context:t,request:e,requestBody:o});let i=await Wn(e,t);return await Ph({context:t,request:e,requestBody:o,response:i,startedAt:r}),i}n(Eh,"McpProxyHandler");export{xc as McpAuth0OAuthInboundPolicy,qr as McpCapabilityFilterInboundPolicy,_c as McpClerkOAuthInboundPolicy,wc as McpCognitoOAuthInboundPolicy,Rc as McpEntraOAuthInboundPolicy,jn as McpGatewayPlugin,bc as McpGoogleOAuthInboundPolicy,Ic as McpKeycloakOAuthInboundPolicy,Sc as McpLogtoOAuthInboundPolicy,Tc as McpOAuthInboundPolicy,Cc as McpOktaOAuthInboundPolicy,vc as McpOneLoginOAuthInboundPolicy,Ac as McpPingOAuthInboundPolicy,Eh as McpProxyHandler,un as McpTokenExchangeInboundPolicy,kc as McpWorkosOAuthInboundPolicy};
48
+ ></iframe>`}n(np,"renderUpstreamHtml");var fa="application/json",op="application/x-www-form-urlencoded";function fr(e,t){return new h({message:e,extensionMembers:{[g]:"invalid_request"}},t===void 0?void 0:{cause:t})}n(fr,"invalidRequestError");function ip(e){return(e??"").split(";")[0]?.trim().toLowerCase()??""}n(ip,"normalizeContentType");function ap(e,t){return e===t?!0:t===fa&&e.endsWith("+json")}n(ap,"contentTypeMatches");function sp(e,t){if(!t||t.length===0)return;let r=ip(e.headers.get("content-type"));if(!t.some(o=>ap(r,o)))throw fr(`Request body must be ${t.join(" or ")}.`)}n(sp,"assertExpectedContentType");function cp(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 fr(`${r} exceeded the maximum allowed size.`)}n(cp,"assertContentLengthWithinLimit");async function ha(e,t){let r=t.label??"Request body";sp(e,t.expectedContentTypes),cp(e,t.maxBytes,r);let o=await ar(e.body,{maxBytes:t.maxBytes,createLimitError:n(()=>fr(`${r} exceeded the maximum allowed size.`),"createLimitError")});return new TextDecoder().decode(o)}n(ha,"readBoundedTextBody");async function ga(e,t){let r=await ha(e,{...t,expectedContentTypes:[fa]});try{return JSON.parse(r)}catch(o){throw fr("Request body must be valid JSON.",o)}}n(ga,"readBoundedJsonBody");async function ya(e,t){let r=await ha(e,{...t,expectedContentTypes:[op]});return new URLSearchParams(r)}n(ya,"readBoundedFormUrlEncodedBody");Z();Z();import{errors as wa,jwtVerify as Ra,SignJWT as ba}from"jose";import{base64url as dp}from"jose";var up="mcp-browser-login-pkce:",lp=new TextEncoder;async function pp(e){return crypto.subtle.importKey("raw",G(e),{name:"HMAC",hash:"SHA-256"},!1,["sign"])}n(pp,"importHmacKey");async function ln(e){let t=await pp(e.signingKey),r=lp.encode(`${up}${e.stateId}`),o=await crypto.subtle.sign("HMAC",t,G(r));return Be.parse(dp.encode(new Uint8Array(o)))}n(ln,"deriveBrowserLoginPkceVerifier");async function _a(e){let t=await ln(e),r=await Yt(t);return{codeVerifier:t,codeChallenge:r,codeChallengeMethod:He}}n(_a,"deriveBrowserLoginPkceParams");var mp={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},m=class extends Error{static{n(this,"OAuthProtocolError")}errorCode;status;constructor(t,r,o=mp[t],i){super(r,i),this.name="OAuthProtocolError",this.errorCode=t,this.status=o}};var fp=300,hp=d.object({purpose:d.literal("gateway_browser_login"),transactionId:kr,stateId:Tr,exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),gp=d.object({purpose:d.literal("gateway_authorization_setup"),transactionId:kr,stateId:Tr,exp:d.number().int().positive(),iat:d.number().int().positive().optional()});async function Ut(){return oe({purpose:"browser-login",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>Se(e,"browser-login"),"derive")})}n(Ut,"getBrowserLoginKey");async function Ia(){return oe({purpose:"authorization-csrf",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>Se(e,"authorization-csrf"),"derive")})}n(Ia,"getCsrfKey");function Sa(e){return{now:e.now??new Date,ttlSeconds:Ca()}}n(Sa,"readPendingTransactionDependencies");function Ca(){return L().browserLogin.stateTtlSeconds}n(Ca,"readBrowserLoginStateTtlSeconds");function yp(e){let t=H();return K(e)&&t.isActionPath(e.pathname,"/oauth/dev-login")}n(yp,"isLoopbackDevLoginUrl");async function _p(e){let t=L().browserLogin,r=H(),o=new URL(Re("url")),i=new URL(r.actionPath("/oauth/callback"),Ge(e.requestUrl,e.requestHeaders));if(yp(o))return o.searchParams.set("redirect_uri",i.toString()),o.searchParams.set("state",e.state),o;if(o.searchParams.set("response_type","code"),o.searchParams.set("client_id",Re("clientId")),o.searchParams.set("redirect_uri",i.toString()),o.searchParams.set("scope",t.scope),o.searchParams.set("state",e.state),o.searchParams.set("nonce",e.nonce),t.audience&&o.searchParams.set("audience",t.audience),t.pkce===He){let a=await _a({stateId:e.stateId,signingKey:await Ut()});o.searchParams.set("code_challenge",a.codeChallenge),o.searchParams.set("code_challenge_method",a.codeChallengeMethod)}return o}n(_p,"buildBrowserLoginUrl");function wp(e,t){return e.subjectId===t.subjectId}n(wp,"principalsMatch");function va(e){return{subjectId:e.subjectId,...e.roles===void 0?{}:{roles:e.roles}}}n(va,"toPendingPrincipal");function Aa(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:I(e.now),expiresAt:I(de(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 R("identity_context_missing","Authorization setup requires a principal.");return{...t,phase:"awaiting_setup",principal:va(e.principal)}}n(Aa,"createTransactionRecord");async function xa(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 R("oauth_state_reused","Authorization transaction state already exists.");case"invalid_client":throw new m("invalid_client","OAuth client is not registered.");case"redirect_uri_mismatch":throw new m("invalid_request","redirect_uri is not registered for the client.")}}n(xa,"startPendingTransaction");async function Rp(e){return new ba({purpose:"gateway_browser_login",transactionId:e.transactionId,stateId:e.stateId}).setProtectedHeader({alg:V,typ:"JWT"}).setIssuer($).setAudience(W).setIssuedAt().setExpirationTime(Math.floor(Date.now()/1e3)+e.ttlSeconds).sign(await Ut())}n(Rp,"signBrowserLoginState");async function ka(e){return new ba({purpose:"gateway_authorization_setup",transactionId:e.transactionId,stateId:Pr()}).setProtectedHeader({alg:V,typ:"JWT"}).setIssuer($).setAudience(W).setIssuedAt().setExpirationTime(Math.floor(Date.now()/1e3)+e.ttlSeconds).sign(await Ia())}n(ka,"signCsrfToken");async function pn(e){try{let{payload:t}=await Ra(e,await Ut(),{algorithms:[V],issuer:$,audience:W}),r=hp.parse(t);return{transactionId:r.transactionId,stateId:r.stateId}}catch(t){throw t instanceof wa.JWTExpired?R("oauth_state_expired","Browser login state has expired.",t):R("oauth_state_invalid","Browser login state could not be verified.",t)}}n(pn,"verifyBrowserLoginStateToken");async function hr(e){try{let{payload:t}=await Ra(e,await Ia(),{algorithms:[V],issuer:$,audience:W});return{transactionId:gp.parse(t).transactionId}}catch(t){throw t instanceof wa.JWTExpired?R("oauth_state_expired","Authorization setup state has expired.",t):R("oauth_state_invalid","Authorization setup state could not be verified.",t)}}n(hr,"verifyCsrfToken");function mn(e){return e==="consumed"||e==="consumed_already"||e==="stale_hash"?"oauth_state_reused":e==="expired"?"oauth_state_expired":"oauth_state_invalid"}n(mn,"pendingStateErrorCode");function bp(e){return e.kind==="available"?{kind:"available",record:e.transaction}:e}n(bp,"toPendingAuthorizationGetResult");function Ip(e){return e.kind==="advanced"?{kind:"advanced",record:e.transaction}:e}n(Ip,"toPendingAuthorizationAdvanceResult");function fn(e){return e==="principal_mismatch"?"oauth_callback_mismatch":mn(e==="consumed_already"?"consumed_already":e)}n(fn,"setupDecisionErrorCode");async function Ta(e){let t=e.now??new Date,r=await hr(e.csrfToken),o=await b().markAuthorizationSetupApproved({transactionId:r.transactionId,currentStateHash:await k(e.csrfToken),currentPrincipal:{subjectId:e.currentBrowserPrincipal.subjectId},now:I(t)});if(o.kind!=="marked")throw R(fn(o.kind),"Authorization setup state is invalid, expired, or already used.");return Ua({kind:"available",record:o.transaction})}n(Ta,"markSetupApproved");function Ua(e){if(e.kind!=="available")throw R(mn(e.kind),"Authorization setup state is invalid, expired, or already used.");if(e.record.phase!=="awaiting_setup")throw R("oauth_state_invalid","Authorization setup state is not in the setup phase.");return e.record}n(Ua,"requireAwaitingSetup");function Sp(e){if(!wp(e.currentBrowserPrincipal,e.transaction.principal))throw R("oauth_callback_mismatch","Authorization setup state does not match the current browser session.")}n(Sp,"requireCurrentPrincipalMatches");async function Pa(e){let t=e.now??new Date,r=Ca(),o=Ur(),i=Pr(),a=await Rp({transactionId:o,stateId:i,ttlSeconds:r}),c=Aa({id:o,transaction:e.transaction,currentStateHash:await k(a),phase:"awaiting_login",now:t,ttlSeconds:r});if(c.phase!=="awaiting_login")throw R("oauth_state_invalid","Authorization transaction did not start in login phase.");let s=await xa({record:c,client:e.transaction.client});if(s.phase!=="awaiting_login")throw R("oauth_state_invalid","Authorization transaction did not start in login phase.");let u=await _p({state:a,nonce:i,stateId:i,requestUrl:e.requestUrl,...e.requestHeaders===void 0?{}:{requestHeaders:e.requestHeaders}});return{transaction:s,browserLoginStateToken:a,browserLoginUrl:u}}n(Pa,"startAwaitingLogin");async function Ea(e){let{now:t,ttlSeconds:r}=Sa(e),o=Ur(),i=await ka({transactionId:o,ttlSeconds:r}),a=Aa({id:o,transaction:e.transaction,currentStateHash:await k(i),phase:"awaiting_setup",principal:e.principal,now:t,ttlSeconds:r});if(a.phase!=="awaiting_setup")throw R("oauth_state_invalid","Authorization transaction did not start in setup phase.");let c=await xa({record:a,client:e.transaction.client});if(c.phase!=="awaiting_setup")throw R("oauth_state_invalid","Authorization transaction did not start in setup phase.");return{transaction:c,csrfToken:i}}n(Ea,"startAwaitingSetup");async function Oa(e){let{now:t,ttlSeconds:r}=Sa(e),o=await pn(e.browserLoginStateToken),i=await ka({transactionId:o.transactionId,ttlSeconds:r}),a=Ip(await b().advancePendingAuthorization({transactionId:o.transactionId,expectedPhase:"awaiting_login",currentStateHash:await k(e.browserLoginStateToken),nextStateHash:await k(i),nextPhase:"awaiting_setup",principal:va(e.principal),now:I(t)}));if(a.kind!=="advanced")throw R(mn(a.kind),"Browser login state is invalid, expired, or already used.");if(a.record.phase!=="awaiting_setup")throw R("oauth_state_invalid","Browser login did not advance to setup.");return{transaction:a.record,csrfToken:i}}n(Oa,"completeLogin");async function qa(e){let t=await hn(e);return Sp({transaction:t,currentBrowserPrincipal:e.currentBrowserPrincipal}),t}n(qa,"getSetup");async function hn(e){let t=e.now??new Date,r=await hr(e.csrfToken);return Ua(bp(await b().readPendingAuthorization({transactionId:r.transactionId,currentStateHash:await k(e.csrfToken),now:I(t)})))}n(hn,"getSetupTransaction");async function Cp(e){let t=await hr(e.csrfToken),r=le(),o=I(de(e.now,fp)),i=await b().decideAuthorizationSetup({decision:"approve",transactionId:t.transactionId,currentStateHash:await k(e.csrfToken),currentPrincipal:{subjectId:e.currentBrowserPrincipal.subjectId},authorizationCodeHash:await k(r),authorizationCodeExpiresAt:o,grantId:So(),now:I(e.now)});if(i.kind!=="approved")throw R(i.kind==="cancelled"?"oauth_state_invalid":fn(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(Cp,"createAuthorizationCodeRedirectWithDecision");async function vp(e){let t=await hr(e.csrfToken),r=await b().decideAuthorizationSetup({decision:"cancel",transactionId:t.transactionId,currentStateHash:await k(e.csrfToken),currentPrincipal:{subjectId:e.currentBrowserPrincipal.subjectId},now:I(e.now)});if(r.kind!=="cancelled")throw R(r.kind==="approved"?"oauth_state_invalid":fn(r.kind),"Authorization setup state is invalid, expired, or already used.");return Ap({redirectUri:r.transaction.redirectUri,clientState:r.transaction.clientState})}n(vp,"createCancelRedirectWithDecision");function Ap(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(Ap,"buildClientCancelRedirect");async function Ma(e){let t=e.now??new Date;return Cp({csrfToken:e.csrfToken,currentBrowserPrincipal:e.currentBrowserPrincipal,now:t})}n(Ma,"approve");async function Da(e){let t=e.now??new Date;return vp({csrfToken:e.csrfToken,currentBrowserPrincipal:e.currentBrowserPrincipal,now:t})}n(Da,"cancel");Z();import{createRemoteJWKSet as xp,errors as ot,jwtVerify as ja,SignJWT as kp}from"jose";var _n="zuplo_mcp_session",Tp=d.object({purpose:d.literal("gateway_browser_session"),sub:ct,browserLoginOrigin:d.string().min(1),roles:d.array(d.string().min(1)).optional(),exp:d.number().int().positive(),iat:d.number().int().positive().optional()}),Up=d.object({id_token:d.string().min(1),token_type:d.string().min(1).optional(),expires_in:d.number().optional(),access_token:d.string().min(1).optional(),refresh_token:d.string().min(1).optional(),scope:d.string().min(1).optional()}),Pp=d.object({error:d.string().min(1).optional(),error_description:d.string().min(1).optional(),error_uri:d.string().min(1).optional()}),Ep=d.object({sub:ct,nonce:d.string().min(1)}).catchall(d.unknown()),gn;function Op(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(Op,"parseCookieHeader");async function za(){return oe({purpose:"browser-session",keyMaterialPurpose:"oauth-state-signing",derive:n(e=>Se(e,"browser-session"),"derive")})}n(za,"getBrowserSessionKey");function yn(e,t){let r=new URL(q(e,t)),o=[`${_n}=`,"Path=/","HttpOnly","SameSite=Lax","Max-Age=0"];return r.protocol==="https:"&&o.push("Secure"),o.join("; ")}n(yn,"buildBrowserSessionEvictionCookie");function qp(e){let t=new URL(q(e.requestUrl,e.requestHeaders)),r=[`${_n}=${encodeURIComponent(e.value)}`,"Path=/","HttpOnly","SameSite=Lax",`Max-Age=${e.ttlSeconds}`];return t.protocol==="https:"&&r.push("Secure"),r.join("; ")}n(qp,"serializeSessionCookie");function Ha(){return new URL(Re("url")).origin}n(Ha,"readBrowserLoginOrigin");function Mp(e){let t=Pp.safeParse(e);if(!t.success)return{};let r={};return t.data.error!==void 0&&(r.idpError=t.data.error),t.data.error_description!==void 0&&(r.idpErrorDescription=t.data.error_description.slice(0,256)),t.data.error_uri!==void 0&&(r.idpErrorUri=t.data.error_uri.slice(0,256)),r}n(Mp,"readIdpErrorFields");function Dp(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(Dp,"readJwtFailureKind");function jp(e){return e instanceof Error&&"cause"in e?e.cause:e}n(jp,"readErrorCause");function zp(e){if(e!==null&&typeof e=="object"&&"extensionMembers"in e)return e.extensionMembers?.gatewayCode}n(zp,"readRuntimeGatewayCode");function Hp(){if(!gn){let e=L();gn=xp(new URL(e.oidc.jwksUrl),{timeoutDuration:e.browserLogin.remoteTimeoutMs})}return gn}n(Hp,"readFederatedJwks");function Ba(e){if(!e.user)throw R("authentication_required","The browser login callback did not include an authenticated Zuplo principal.");return Te(e.user,e.url)}n(Ba,"resolveCurrentRequestPrincipal");async function gr(e,t={}){let r=Op(e.headers.get("cookie")).get(_n);if(!r)return{};try{let{payload:o}=await ja(r,await za(),{algorithms:[V],issuer:$,audience:W}),i=Tp.parse(o);if(i.browserLoginOrigin!==Ha())return{evictCookie:yn(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 ot.JWTExpired?{evictCookie:yn(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:yn(e.url,e.headers)})}}n(gr,"readBrowserSession");async function yr(e){let t=L().browserLogin.sessionTtlSeconds,r={purpose:"gateway_browser_session",sub:e.principal.subjectId,browserLoginOrigin:Ha()};e.principal.roles&&(r.roles=e.principal.roles);let o=await new kp(r).setProtectedHeader({alg:V,typ:"JWT"}).setIssuer($).setAudience(W).setIssuedAt().setExpirationTime(Math.floor(Date.now()/1e3)+t).sign(await za());return qp({value:o,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,ttlSeconds:t})}n(yr,"createBrowserSessionCookie");async function Bp(e){let t=L(),r=Re("tokenUrl"),o=Re("clientId"),i=Re("clientSecret"),a=new URL(H().actionPath("/oauth/callback"),Ge(e.requestUrl,e.requestHeaders)).toString(),c=new URLSearchParams({grant_type:"authorization_code",code:e.code,redirect_uri:a,client_id:o,client_secret:i});if(t.browserLogin.pkce===He){let s=await ln({stateId:e.stateId,signingKey:await Ut()});c.set("code_verifier",s)}try{let{response:s,json:u}=await sr(r,{method:"POST",headers:{accept:"application/json","content-type":"application/x-www-form-urlencoded"},body:c},{maxResponseBytes:32768,problemCode:"browser_login_verification_failed",timeoutMs:t.browserLogin.remoteTimeoutMs,context:e.context});if(!s.ok){let y=Mp(u);throw e.context?.log.warn({event:"federated_token_exchange_failed",code:"provider_access_denied",idpHost:O(r),idpStatus:s.status,...y},"Federated browser login token exchange returned non-2xx from the identity provider"),R({code:"provider_access_denied",privateDetail:"Federated browser login token exchange failed.",cause:new Error(`IdP token exchange failed (status=${s.status}${y.idpError?` idp_error=${y.idpError}`:""}${y.idpErrorDescription?` idp_error_description=${y.idpErrorDescription}`:""})`)})}let p=Up.parse(u),f;try{({payload:f}=await ja(p.id_token,Hp(),{issuer:t.oidc.issuer,audience:o}))}catch(y){let P={};throw N(P,"error",y),e.context?.log.warn({event:"federated_id_token_verification_failed",code:"browser_login_verification_failed",failureKind:Dp(y),idpHost:O(r),expectedIssuer:t.oidc.issuer,...P},"Federated id_token failed jose verification"),y}if(f.nonce!==e.nonce)throw e.context?.log.warn({event:"federated_nonce_mismatch",code:"oauth_callback_mismatch",idpHost:O(r),nonceMissingFromIdToken:f.nonce===void 0},"Federated id_token nonce did not match the signed gateway state"),R("oauth_callback_mismatch","Federated browser login nonce did not match the signed gateway state.");let w=Ep.parse(f);return{principal:Te({sub:w.sub,data:w},e.requestUrl),subjectToken:{token:p.id_token,tokenType:ut,expiresAt:typeof f.exp=="number"?I(new Date(f.exp*1e3)):void 0}}}catch(s){let u=ce(s)??zp(s);throw u!==void 0&&u!=="browser_login_verification_failed"?s:R("browser_login_verification_failed","Federated browser login callback could not be verified.",jp(s))}}n(Bp,"exchangeFederatedAuthorizationCode");async function La(e){let t=typeof e.request.query.code=="string"?e.request.query.code:void 0;if(t)return Bp({code:t,nonce:e.stateId,stateId:e.stateId,requestUrl:e.request.url,requestHeaders:e.request.headers,context:e.context});let r=await gr(e.request,{context:e.context});if(r.principal)return{principal:r.principal};throw R("oauth_callback_mismatch","Federated browser login callback is missing an authorization code.")}n(La,"resolveBrowserLoginCallbackIdentity");Z();var Lp=new Set(["about","blob","data","file","ftp","ftps","javascript","mailto","urn","ws","wss"]);function Np(e){return e.protocol.replace(/:$/u,"").toLowerCase()}n(Np,"readScheme");function Jp(e){return e.protocol==="https:"}n(Jp,"isSpecCompliantRedirectUri");function Gp(e){let t=Np(e);return t.length>0&&t!=="http"&&t!=="https"&&!Lp.has(t)}n(Gp,"isNativeAppCustomSchemeRedirectUri");var Ja=[{id:"oauth.redirect_uri.https",mode:"strict",accepts:n(e=>Jp(e),"accepts")},{id:"oauth.redirect_uri.loopback_http",mode:"native_app",accepts:n(e=>K(e),"accepts"),matches:n((e,t)=>K(e)&&K(t)&&e.pathname===t.pathname&&e.search===t.search,"matches")},{id:"oauth.redirect_uri.custom_scheme",mode:"native_app",accepts:n(e=>Gp(e),"accepts")}];function Ga(e){let t=Ja.find(r=>r.accepts(e.url));return t===void 0?{kind:"rejected"}:{kind:"allowed",ruleId:t.id,mode:t.mode}}n(Ga,"evaluateBuiltInRedirectUriCompatibility");function Na(e){try{return new URL(e)}catch{return}}n(Na,"parseUrl");function Fa(e){if(e.registeredRedirectUri===e.requestedRedirectUri)return!0;let t=Na(e.registeredRedirectUri),r=Na(e.requestedRedirectUri);return t===void 0||r===void 0?!1:Ja.some(o=>o.matches?.(t,r))}n(Fa,"redirectUriMatchesBuiltInCompatibility");var Fp=1e4,$p=5*1024,Zp=0,Kp=2160*60*60,$a=["authorization_code","refresh_token",$t,be],Wp=["authorization_code","refresh_token"],Za=[Ro],Vp=["code"],Yp=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($a)).min(1).max($a.length).optional(),authorization_grant_profiles_supported:d.array(d.enum(Za)).min(1).max(Za.length).optional(),response_types:d.array(d.enum(Vp)).min(1).max(1).optional(),scope:d.literal(M).optional(),token_endpoint_auth_method:Io.optional(),jwks_uri:d.string().min(1).optional()});function Xp(e){try{let t=new URL(e);return(t.protocol==="https:"||t.protocol==="http:"&&K(t))&&t.pathname!=="/"}catch{return!1}}n(Xp,"isCimdClientIdCandidate");function Ka(e,t){throw new m("invalid_client",Po({clientId:e})??"OAuth client is not registered.",void 0,t===void 0?void 0:{cause:t})}n(Ka,"invalidCimdClientError");function it(e,t="invalid_request"){if(Qp(e))throw new m(t,"redirect_uris must not include raw whitespace or control characters.");let r;try{r=new URL(e)}catch{throw new m(t,"redirect_uris must be absolute URIs.")}if(r.hash||r.username||r.password)throw new m(t,"redirect_uris must not include credentials or fragments.");if(Ga({url:r}).kind==="rejected")throw new m(t,"redirect_uris must use HTTPS, loopback HTTP, or a native-app private-use URI scheme.")}n(it,"assertValidRedirectUri");function Qp(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(Qp,"hasForbiddenRawRedirectUriCharacter");async function em(e){let{response:t,json:r}=await di(e.initialUrl,{headers:{accept:"application/json"}},{maxRedirects:Zp,maxResponseBytes:$p,timeoutMs:Fp});if(!t.ok)throw R("invalid_request","CIMD metadata could not be fetched.");let o=Kt(r);for(let i of o.redirect_uris)it(i,"invalid_request");if(o.jwks_uri!==void 0&&pt(o.jwks_uri),o.client_id!==e.clientId)throw R("invalid_request","Fetched CIMD client_id must exactly match the requested client_id.");return o}n(em,"fetchCimdMetadata");async function tm(e){let t=Wt(e),r=await em({clientId:e,initialUrl:t});return{kind:"cimd",clientId:e,metadata:r}}n(tm,"resolveCimdClient");async function _r(e,t){let r=ue.parse(e);if(Xp(r)){L().gateway.downstreamCimdEnabled||Ka(r);try{return await tm(r)}catch(i){Ka(r,i)}}let o=await b().readClient({clientId:r});if(o.kind==="found"){let i=o.client,a=Oo(i.clientId),c=a===void 0?i.tokenEndpointAuthMethod:"private_key_jwt",s=i.jwksUri??a;if(c==="private_key_jwt"&&s===void 0)throw new m("invalid_client","Dynamic private_key_jwt client is missing JWKS metadata. Re-run client registration before authorization.");let u=Kt({client_id:i.clientId,client_name:i.clientName,redirect_uris:i.redirectUris,token_endpoint_auth_method:c,...s===void 0?{}:{jwks_uri:s}}),p={kind:"dcr",clientId:r,metadata:u};return i.hashedClientSecret&&(p.hashedClientSecret=i.hashedClientSecret),p}throw new m("invalid_client",r.startsWith("dcr:")?"Dynamic client is not registered. Re-run client registration before authorization.":"OAuth client is not registered.")}n(_r,"resolveClient");function Wa(e,t){if(!e.metadata.redirect_uris.some(r=>Fa({registeredRedirectUri:r,requestedRedirectUri:t})))throw R("invalid_request","redirect_uri is not registered for the client.")}n(Wa,"assertRedirectRegistered");function rm(e){return e===void 0?[...Wp]:Array.from(new Set(e))}n(rm,"normalizeGrantTypes");function nm(e){try{pt(e)}catch(t){throw new m("invalid_client_metadata","jwks_uri must be an HTTPS URL with a path, no credentials or fragment, and must not point at a blocked host.",void 0,{cause:t})}}n(nm,"assertValidDcrJwksUri");function om(e){return e.tokenEndpointAuthMethod==="private_key_jwt"&&e.jwksUri!==void 0?ue.parse(Eo({clientId:crypto.randomUUID(),jwksUri:e.jwksUri})):ue.parse(`dcr:${crypto.randomUUID()}`)}n(om,"createDcrClientId");function at(e){if(e===void 0||e===M)return M;throw new m("invalid_request",`Only the ${M} scope is supported.`)}n(at,"assertSupportedOAuthScope");function Me(e,t,r){let o;try{o=new URL(t)}catch{throw new m("invalid_target","resource must be an absolute URI.")}if(o.hash)throw new m("invalid_target","resource must not include a fragment.");if(o.protocol!=="https:"&&!K(o))throw new m("invalid_target","resource must use HTTPS except loopback HTTP resources in local development.");let i=q(e,r),a=_o(),c=a?[...a.byOperationId.values()].find(s=>new URL(s.routePath,i).toString()===t):void 0;if(!c)throw new m("invalid_target","resource must match a published MCP route.");return c}n(Me,"resolveResource");async function Va(e){let t;try{t=Yp.parse(e)}catch(y){if(y instanceof d.ZodError){let P=y.issues.some(x=>x.path[0]==="redirect_uris");throw new m(P?"invalid_redirect_uri":"invalid_client_metadata",y.issues[0]?.message??"Client metadata is invalid.",void 0,{cause:y})}throw y}for(let y of t.redirect_uris)it(y,"invalid_redirect_uri");if(t.token_endpoint_auth_method==="private_key_jwt"&&t.jwks_uri===void 0)throw new m("invalid_client_metadata","jwks_uri is required for private_key_jwt clients.");t.jwks_uri!==void 0&&nm(t.jwks_uri);let r=new Date,o=t.token_endpoint_auth_method??"none",i=o==="private_key_jwt"?"none":o,a=om({tokenEndpointAuthMethod:o,jwksUri:t.jwks_uri}),c=Kt({client_id:a,client_name:t.client_name??"Dynamically registered MCP client",redirect_uris:t.redirect_uris,token_endpoint_auth_method:o,...t.jwks_uri===void 0?{}:{jwks_uri:t.jwks_uri}}),s=de(r,Kp),u=Math.floor(r.getTime()/1e3),p=Math.floor(s.getTime()/1e3),f={client_id:c.client_id,client_name:c.client_name,redirect_uris:c.redirect_uris,grant_types:rm(t.grant_types),authorization_grant_profiles_supported:t.authorization_grant_profiles_supported,response_types:["code"],scope:M,token_endpoint_auth_method:c.token_endpoint_auth_method,client_id_issued_at:u,jwks_uri:c.jwks_uri},w={clientId:c.client_id,clientName:c.client_name,redirectUris:c.redirect_uris,tokenEndpointAuthMethod:i,createdAt:I(r),clientExpiresAt:I(s)};if(o==="client_secret_basic"||o==="client_secret_post"){let y=le();w.hashedClientSecret=await k(y),w.clientSecretExpiresAt=I(s),f.client_secret=y,f.client_secret_expires_at=p,f.client_secret_issued_at=u}if((await b().registerClient(w)).kind==="already_exists")throw R("invalid_request","OAuth client is already registered.");return f}n(Va,"registerDownstreamClient");function im(e){return e?.metadata?.idpSubjectTokenType!==Fe&&e?.metadata?.idpSubjectTokenExpiresAt!==void 0&&new Date(e.metadata.idpSubjectTokenExpiresAt).getTime()<=Date.now()?!1:e?.status==="active"&&e.metadata?.encryptedIdpSubjectToken!==void 0&&e.metadata.idpSubjectTokenType!==void 0}n(im,"hasStoredIdJagSubjectTokenBinding");async function Ya(e){let t=Je(e.principal.subjectId);return(await b().batchGetUpstreamConnections([{owner:t,upstreamServerId:e.connection.upstreamServerId,authProfileId:e.connection.authProfileId}]))[0]}n(Ya,"readIdJagSubjectConnection");async function wn(e){let t=ee().byOperationId.get(e.operationId);if(t?.connection===void 0||t.connection.authMode!=="id-jag")return!1;let r=await Ya({connection:t.connection,principal:e.principal});return!im(r)}n(wn,"requiresIdJagSubjectTokenBinding");async function Xa(e){if(e.subjectToken===void 0)return;let t=ee().byOperationId.get(e.transaction.operationId);if(t?.connection===void 0||t.connection.authMode!=="id-jag"||e.principal.subjectId!==e.transaction.principal.subjectId)return;let r=await Ya({connection:t.connection,principal:e.principal});return b().upsertUpstreamConnection({id:r?.id??Vt(),ownerMode:"user",subjectId:e.transaction.principal.subjectId,upstreamServerId:t.connection.upstreamServerId,authProfileId:t.connection.authProfileId,status:"active",encryptedAccessToken:r?.encryptedAccessToken,encryptedRefreshToken:r?.encryptedRefreshToken,scopes:r?.scopes??[],expiresAt:r?.expiresAt,metadata:{...r?.metadata??{},encryptedIdpSubjectToken:await me(e.subjectToken.token),idpSubjectTokenType:e.subjectToken.tokenType,idpSubjectTokenExpiresAt:e.subjectToken.expiresAt}})}n(Xa,"bindIdJagSubjectTokenForAuthorizationTransaction");function wr(e){return C`<img class="card__icon" src="${e.iconHref}" alt="" width="48" height="48" referrerpolicy="no-referrer" onerror=" this.onerror = null; this.src = '${e.fallbackIconHref}'; " />`}n(wr,"renderShellIcon");function Qa(e){return C`<form class="actions" method="post" action="${e.setupAction}" ${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(Qa,"renderActions");var es=fe('<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 ts(e){return C`<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(ts,"renderBannerWarning");var WR=fe('<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>'),VR=fe('<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 YR=fe('<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 am="data:,",rs=C`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);"`,ns=C`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 sm(e,t,r){if(e)try{let o=new URL(t).origin,i=new URL(e,o);return i.origin!==o||!i.pathname.startsWith(r.actionPath("/auth/connections/"))?void 0:i.toString()}catch{return}}n(sm,"safeGatewayConnectHref");function cm(e){return e.some(r=>r.ownerMode==="user"&&r.status!=="active")?"setup":"grant"}n(cm,"deriveMode");function dm(e){return Qa({state:e.state,setupAction:e.gateway.actionPath("/oauth/setup"),submitOnceAttrs:rs,authorizeAttrs:te})}n(dm,"renderActions");function Rn(e,t,r,o){for(let i of e){if(i.ownerMode!=="user"||i.status!==r)continue;let a=sm(i.connectUrl,t,o);if(a)return a}}n(Rn,"firstUserConnectHref");function um(e){let t=e.connectHref===void 0?te:C`<a class="button button--primary" href="${e.connectHref}" ${ns}>Connect</a>`;return C`<form class="actions" method="post" action="${e.gateway.actionPath("/oauth/setup")}" ${rs}><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(um,"renderSetupActions");function lm(e){return e?C`<span class="reconnect-action"><a class="button button--secondary reconnect-button" href="${e}" ${ns}>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>`:te}n(lm,"renderReconnectAction");function pm(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(pm,"isRenderableIconHref");function os(e){return e?.find(t=>pm(t.src))?.src}n(os,"readIconHref");function mm(e){return os(e.serverIcons)??(e.transportHost===void 0?void 0:Wr(e.transportHost).src)}n(mm,"readUpstreamIconHref");function fm(e){let t=os(e.routeIcons);if(t!==void 0)return t;for(let r of e.upstreams){let o=mm(r);if(o!==void 0)return o}}n(fm,"readHeaderIconHref");function hm(e){let t=e.setupMessage===void 0?te:ts({icon:es,message:e.setupMessage});return C`<p class="card__subtitle">Authorize '<strong>${e.clientDisplayName}</strong>' to access '<strong>${e.routeDisplayName}</strong>' on your behalf?</p>${t}`}n(hm,"renderBody");function bn(e){let t=cm(e.upstreams),r=Rn(e.upstreams,e.gatewayOrigin,"not_connected",e.gateway),o=Rn(e.upstreams,e.gatewayOrigin,"reconsent_required",e.gateway),i=Rn(e.upstreams,e.gatewayOrigin,"active",e.gateway),a=t==="setup"?r??o:void 0,c=t==="setup"?e.upstreams.find(p=>p.ownerMode==="user"&&p.status!=="active"&&p.connectUrl===void 0&&p.setupMessage!==void 0)?.setupMessage:void 0,s=fm({routeIcons:e.routeIcons,upstreams:e.upstreams}),u=t==="setup"?C`<footer class="card__footer">${um({state:e.state,connectHref:a,gateway:e.gateway})}</footer>`:C`<footer class="card__footer">${lm(i)}${dm({state:e.state,gateway:e.gateway})}</footer>`;return et(rt({title:`Authorize access \xB7 ${e.routeDisplayName}`,iconHref:s??am,styles:tt,headerIcon:s===void 0?te:wr({iconHref:s,fallbackIconHref:nr}),heading:"Authorize access",subhead:te,body:hm({routeDisplayName:e.routeDisplayName,clientDisplayName:e.clientDisplayName,setupMessage:c}),footer:u}))}n(bn,"renderConsentPage");var gm=1e4,is="mcp-session-id",ym;function us(){return{tools:[],prompts:[],resources:[]}}n(us,"emptyCapabilities");function as(){return new Headers({accept:"application/json, text/event-stream","content-type":"application/json","mcp-protocol-version":Er})}n(as,"buildReadinessHeaders");async function ss(e){if(e.type==="bearer_token"){let o=as();return o.set("authorization",`Bearer ${e.token}`),o}let t=await e.provider.tokens();if(!t)return;let r=as();return r.set("authorization",`${t.token_type??"Bearer"} ${t.access_token}`),r}n(ss,"buildAsyncCredentialHeaders");function cs(e){return new Request(e.upstreamUrl,{method:"POST",headers:e.headers,body:JSON.stringify(Gt.parse({jsonrpc:Jt,id:1,method:"initialize",params:{protocolVersion:Er,capabilities:{},clientInfo:{name:"zuplo-mcp-gateway-readiness",version:"0.0.0"}}}))})}n(cs,"buildInitializePreflight");async function In(e){lt(e.url);let t=new AbortController,r=setTimeout(()=>t.abort(),gm);try{let o=new Request(e,{redirect:"manual",signal:t.signal});return await jt.fetch(o)}finally{clearTimeout(r)}}n(In,"runPreflight");function Sn(e){e.body?.cancel().catch(()=>{})}n(Sn,"releasePreflightBody");async function _m(e){let t=e.response.headers.get(is);if(!t)return;let r=new Headers(e.headers);r.set(is,t),r.delete("content-type");try{let o=await In(new Request(e.upstreamUrl,{method:"DELETE",headers:r}));Sn(o)}catch{}}n(_m,"terminatePreflightSession");async function ls(e){let{response:t}=e;return Sn(t),t.status>=200&&t.status<300?(await _m(e),{kind:"ready",upstreamStatus:t.status,capabilities:us()}):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(ls,"classifyResponse");function ds(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(ds,"connectRequiredResult");async function wm(e){try{return ls({response:await In(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(wm,"classifyPreflight");async function Rm(e){let t=e.route.connection;if(t===void 0)return{kind:"ready",upstreamStatus:204,capabilities:us()};let r=pr(t.upstreamServerId,e.route.operationId),o=Qe(r,e.subjectId),i=e.returnTo===void 0?o:{...o,returnTo:e.returnTo},a=new Request(e.requestUrl,{headers:e.requestHeaders}),c=await Xe({request:a,routeAuth:i,preloadedConnection:e.preloadedConnection});if(c.kind==="connect_required")return ds(c.payload);let s=await ss(c.credential);if(s===void 0)return{kind:"upstream_auth_rejected",status:401,message:"Upstream credential did not produce tokens."};let u=cs({upstreamUrl:t.mcpUrl,headers:s}),p;try{p=await In(u)}catch(U){return{kind:"upstream_unavailable",message:U instanceof Error?U.message:"Upstream MCP server readiness preflight failed."}}if(p.status!==401)return ls({response:p,upstreamUrl:t.mcpUrl,headers:s});Sn(p);let f=await Xe({request:a,routeAuth:i,forceRefresh:!0,preloadedConnection:e.preloadedConnection});if(f.kind==="connect_required")return ds(f.payload);let w=await ss(f.credential);return w===void 0?{kind:"upstream_auth_rejected",status:401,message:"Upstream credential did not produce tokens after refresh."}:wm({request:cs({upstreamUrl:t.mcpUrl,headers:w}),upstreamUrl:t.mcpUrl,headers:w})}n(Rm,"checkUpstreamRouteReadinessImpl");function ps(e){return(ym??Rm)(e)}n(ps,"checkUpstreamRouteReadiness");function bm(e){try{return new URL(e).host}catch{return}}n(bm,"safeUrlHost");function ms(e){return e!==void 0&&e.length>0}n(ms,"hasItems");function Im(e){let t=e.serverInfo?.icons;if(ms(t))return t;let r=or(e.mcpUrl);return r===void 0?void 0:[r]}n(Im,"readServerIcons");async function Sm(e){let{authConfig:t,authMode:r,description:o,displayName:i,mcpUrl:a,ownerMode:c,upstreamServerId:s,authProfileId:u}=e.registeredConnection,p=c==="user",f=p&&r!=="id-jag",w=e.readiness??(p?jo(e.connection):{connected:!0,status:"active"}),U=f?e.readiness?.connectUrl??(e.returnTo!==void 0?await Xr({requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,owner:e.userOwner,initiatedBySubjectId:e.transaction.principal.subjectId,upstreamServerId:s,authProfileId:u,operationId:e.route.operationId,returnTo:e.returnTo}):void 0):void 0,y=t.mode==="id-jag"?t.idJag.scopes:t.oauth.scopes;return{upstreamServerId:s,authProfileId:u,authMode:r,ownerMode:c,upstreamDisplayName:i,description:o,transportHost:bm(a),scopesRequested:ms(y)?y:void 0,serverIcons:Im(e.registeredConnection),status:w.status,connected:w.connected,capabilities:{tools:[],prompts:[],resources:[]},connectUrl:U,setupMessage:e.setupMessage,updatedAt:p&&"updatedAt"in w&&w.updatedAt!==void 0?w.updatedAt:void 0,expiresAt:e.readiness?.expiresAt??e.connection?.expiresAt}}n(Sm,"buildSetupRequirement");function fs(e){let t=ee().byOperationId.get(e);if(!t)throw R("unknown_mcp_route",`Unknown MCP route: ${e}`);return t}n(fs,"requireRoute");async function Cn(e){let t=fs(e.transaction.operationId),r=Je(e.transaction.principal.subjectId),o=t.connection;if(o===void 0)return[];let a=o.ownerMode==="user"?(await b().batchGetUpstreamConnections([{owner:r,upstreamServerId:o.upstreamServerId,authProfileId:o.authProfileId}]))[0]:void 0,c=await ps({requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,route:t,subjectId:e.transaction.principal.subjectId,preloadedConnection:a,returnTo:e.returnTo}),s="connectionStatus"in c?c.connectionStatus:void 0,u=(c.kind==="connect_required"||c.kind==="admin_setup_required")&&c.payload.authUrl!==void 0?c.payload.authUrl:void 0,p=c.kind==="admin_setup_required"?c.payload.message:void 0;return[await Sm({connection:a,registeredConnection:o,route:t,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,returnTo:e.returnTo,transaction:e.transaction,userOwner:r,setupMessage:p,readiness:s===void 0?void 0:{...s,connectUrl:u}})]}n(Cn,"requirementsForSetup");async function vn(e){let t=fs(e.transaction.operationId),r=await b().readClient({clientId:e.transaction.clientId}),o=r.kind==="found"?r.client:void 0,i={gatewayOrigin:q(e.requestUrl,e.requestHeaders),routeDisplayName:t.connection?.displayName??t.operationId,clientDisplayName:o?.clientName??String(e.transaction.clientId),principalLabel:e.transaction.principal.subjectId},a=t.connection?.description;return a!==void 0&&(i.routeDescription=a),i}n(vn,"consentContext");function An(e){return e.some(t=>t.ownerMode==="user"&&t.status!=="active")}n(An,"hasUnresolvedUserUpstream");var Cm=["mcp_user"],vm="dev-browser-user",Am=["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(" "),xm=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:eo,state:d.string().min(1).optional(),scope:d.literal(M).default(M)}),km=d.enum(["continue","approve","cancel"]).default("continue"),Tm=d.object({state:d.string().min(1),decision:km}),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 hs(e){return typeof e=="string"&&e.length>0?e:void 0}n(hs,"readQueryString");function Um(e,t){let r=hs(e.query.resource);if(t===void 0){if(r!==void 0)return r;throw new m("invalid_target",Am)}let o=xo(t,e.url,e.headers);if(r===void 0||r===o)return o;throw new m("invalid_target","resource must match the scoped OAuth authorization endpoint resource.")}n(Um,"requireAuthorizeResource");async function Pm(e,t){let r={};t!==void 0&&(r.context=t);let o=await gr(e,r);if(o.principal)return{principal:o.principal};if(!e.user)return o.evictCookie===void 0?{}:{setCookie:o.evictCookie};let i=Ba(e);return{principal:i,setCookie:await yr({principal:i,requestUrl:e.url,requestHeaders:e.headers})}}n(Pm,"resolveBrowserPrincipal");async function Em(e,t){let r={};t!==void 0&&(r.context=t);let o=await gr(e,r);if(!o.principal)throw R("authentication_required","Authorization setup requires a current browser session.");return o.principal}n(Em,"requireSetupPrincipal");function gs(e){return`${H().actionPath("/oauth/setup")}?state=${encodeURIComponent(e)}`}n(gs,"buildSetupReturnTo");async function ys(e){let t=await Cn({transaction:e.transaction,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,returnTo:gs(e.csrfToken)}),r=await vn({transaction:e.transaction,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders}),o={kind:"setup_page",html:bn({state:e.csrfToken,operationId:e.transaction.operationId,gateway:H(),upstreams:t,...r})};return e.setCookie!==void 0&&(o.setCookie=e.setCookie),o}n(ys,"renderSetup");function Om(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(Om,"toAuthorizationTransactionClient");async function xn(e,t={}){let r=xm.parse({...e.query,resource:Um(e,t.operationId),state:hs(e.query.state)}),o=at(r.scope);it(r.redirect_uri,"invalid_request");let i=new Date,a=ue.parse(r.client_id),c=await _r(r.client_id,i);Wa(c,r.redirect_uri);try{let s=Me(e.url,r.resource,e.headers),u=Om(c);t.context?.log.info({event:"oauth_authorize_request_parsed",clientId:a,operationId:s.operationId,scope:o,hasClientState:r.state!==void 0},"Downstream OAuth authorize: request parsed and client resolved"),t.context&&v(t.context,{eventType:S.MCP_OAUTH_AUTHORIZE_STARTED,outcome:"success",virtualServerName:s.operationId,attributes:{clientId:a,scope:o,responseType:r.response_type}});let p={clientId:c?.clientId??a,...u===void 0?{}:{client:u},redirectUri:r.redirect_uri,resource:r.resource,operationId:s.operationId,scope:o,codeChallenge:r.code_challenge,codeChallengeMethod:r.code_challenge_method,...r.state===void 0?{}:{clientState:r.state}},{principal:f,setCookie:w}=await Pm(e,t.context),U=f===void 0?!1:await wn({operationId:s.operationId,principal:f});if(!f||U){let P=await Pa({transaction:p,requestUrl:e.url,requestHeaders:e.headers,now:i});t.context?.log.info({event:"oauth_authorize_awaiting_login",clientId:a,operationId:s.operationId,reason:f?"id_jag_subject_binding_missing":"no_browser_session"},"Downstream OAuth authorize: redirecting to browser login");let x={kind:"redirect",location:P.browserLoginUrl};return w!==void 0&&(x.setCookie=w),x}let y=await Ea({transaction:p,principal:f,now:i});return t.context?.log.info({event:"oauth_authorize_awaiting_setup",clientId:a,operationId:s.operationId,subjectId:f.subjectId},"Downstream OAuth authorize: rendering consent/setup page"),t.context&&v(t.context,{eventType:S.MCP_OAUTH_AUTHORIZE_AWAITING_SETUP,outcome:"success",virtualServerName:s.operationId,attributes:{clientId:a,scope:o,responseType:r.response_type,subjectId:f.subjectId}}),ys({transaction:y.transaction,csrfToken:y.csrfToken,requestUrl:e.url,requestHeaders:e.headers,setCookie:w})}catch(s){throw qm({redirectUri:r.redirect_uri,clientState:r.state,cause:s})}}n(xn,"authorizeDownstreamClient");function qm(e){if(e.cause instanceof Ae)return e.cause;let t=Mm(e.cause);return t?new Ae({redirectUri:e.redirectUri,clientState:e.clientState,errorCode:t.errorCode,errorDescription:t.errorDescription,cause:e.cause}):e.cause}n(qm,"toDownstreamAuthorizeRedirectError");function Mm(e){if(e instanceof m)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(Mm,"mapToOAuthRedirectError");async function _s(e,t={}){let r=typeof e.query.error=="string"?e.query.error:void 0;if(r){let p=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,...p===void 0?{}:{idpErrorDescription:p},...f===void 0?{}:{idpErrorUri:f}},"Identity provider redirected browser-login callback with an error"),R("provider_access_denied",p??"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"),R("oauth_state_invalid","Browser login callback is missing state.");let i=await pn(o),a={request:e,stateId:i.stateId};t.context!==void 0&&(a.context=t.context);let c=await La(a),s=await Oa({browserLoginStateToken:o,principal:c.principal});if(await Xa({transaction:s.transaction,principal:c.principal,subjectToken:c.subjectToken}),await wn({operationId:s.transaction.operationId,principal:c.principal}))throw R("browser_login_verification_failed","The identity provider did not return the subject token required for XAA / ID-JAG.");let u=await ys({transaction:s.transaction,csrfToken:s.csrfToken,requestUrl:e.url,requestHeaders:e.headers});return u.setCookie=await yr({principal:c.principal,requestUrl:e.url,requestHeaders:e.headers}),u}n(_s,"completeBrowserLoginCallback");async function ws(e){let t=L(),r=new URL(e.url);if(!K(r))throw R("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 R("oauth_state_invalid","Local browser login is missing state.");let i=H().actionPath("/oauth/callback"),a=new URL(typeof e.query.redirect_uri=="string"?e.query.redirect_uri:i,q(e.url)),c=new URL(q(e.url)).origin;if(a.origin!==c||a.pathname!==i)throw R("oauth_callback_mismatch",`Local browser login redirect_uri must target this gateway's ${i} route.`);a.searchParams.set("state",o);let s={subjectId:ct.parse(vm),roles:Cm};return{kind:"redirect",location:a,setCookie:await yr({principal:s,requestUrl:e.url,requestHeaders:e.headers})}}n(ws,"completeLocalDevBrowserLogin");function Dm(e){let t=e.method==="POST"?e.body:e.query;return Tm.parse(t)}n(Dm,"readSetupContinueRequest");async function Rs(e){let{state:t,decision:r}=Dm({method:e.request.method,query:e.request.query,body:e.body}),o=new Date,i=await hn({csrfToken:t,now:o}),a=await Em(e.request,e.context);if(r==="cancel")return{kind:"redirect",location:await Da({csrfToken:t,currentBrowserPrincipal:a,now:o})};let c=await qa({csrfToken:t,currentBrowserPrincipal:a,now:o}),s=await Cn({transaction:c,requestUrl:e.request.url,requestHeaders:e.request.headers,returnTo:gs(t)});if(r==="approve"&&An(s)&&await Ta({csrfToken:t,currentBrowserPrincipal:a,now:o}),An(s)){let u=await vn({transaction:c,requestUrl:e.request.url,requestHeaders:e.request.headers});return{kind:"setup_page",html:bn({state:t,operationId:c.operationId,gateway:H(),upstreams:s,...u})}}return{kind:"redirect",location:await Ma({csrfToken:t,currentBrowserPrincipal:a,now:o})}}n(Rs,"continueDownstreamAuthorizeSetup");Z();import{createLocalJWKSet as Wm,decodeJwt as Vm,errors as Et,jwtVerify as Ym}from"jose";Z();import{createRemoteJWKSet as jm,decodeJwt as zm,decodeProtectedHeader as Hm,errors as Pt,jwtVerify as Bm}from"jose";var vs=30,T=d.string().min(1),Lm=d.union([T,d.array(T).min(1)]),Nm=d.union([T,d.array(T).min(1)]),Jm=d.object({type:T,locations:d.array(T).optional(),actions:d.array(T).optional(),datatypes:d.array(T).optional(),identifier:T.optional(),privileges:d.array(T).optional()}).passthrough(),Gm=d.object({iss:d.url(),sub:T,aud:Lm,client_id:T,resource:Nm.optional(),scope:T.optional(),authorization_details:d.array(Jm).optional(),jti:T,iat:d.number().int(),nbf:d.number().int().optional(),exp:d.number().int(),tenant:T.optional(),aud_tenant:T.optional(),aud_sub:T.optional(),sub_id:T.optional(),act:d.unknown().optional(),email:T.optional(),auth_time:d.number().int().optional(),acr:T.optional(),amr:d.array(T).optional(),cnf:d.unknown().optional()}).passthrough();function Y(e){throw new m("invalid_grant",e)}n(Y,"throwInvalidGrant");function Fm(e){return e instanceof Pt.JWTExpired?"expired":e instanceof Pt.JWTClaimValidationFailed?"claim":e instanceof Pt.JWSSignatureVerificationFailed?"signature":e instanceof Pt.JWKSNoMatchingKey?"jwks_no_match":e instanceof Pt.JWTInvalid?"invalid":e instanceof d.ZodError?"schema":"other"}n(Fm,"readJwtFailureKind");function $m(e){return Array.isArray(e.aud)?(e.aud.length!==1&&Y("ID-JAG audience must contain exactly one value."),e.aud[0]):e.aud}n($m,"readSingleAudience");function bs(e){try{let t=Gm.parse(e);return $m(t),t}catch(t){if(t instanceof m)throw t;Y("ID-JAG claims are invalid.")}}n(bs,"parseIdJagClaims");function Zm(e,t){e.idJag.enabled||Y("ID-JAG grant is not enabled.");let r=e.idJag.trustedIssuers.find(o=>o.issuer===t);return r===void 0&&Y("ID-JAG issuer is not trusted."),r}n(Zm,"readTrustedIssuer");function Km(e){let t=e.authorizationDetails;if(t===void 0)return;if(e.allowedTypes===void 0)return t;let r=new Set(e.allowedTypes);return t.filter(o=>r.has(o.type))}n(Km,"readGrantedAuthorizationDetails");function Is(e){if(e.clientAuth.method==="none")throw new m("invalid_client","Client authentication failed.");e.claims.client_id!==e.authenticatedClientId&&Y("ID-JAG client_id must match the authenticated client."),e.trustedIssuer.expectedClientIds!==void 0&&!e.trustedIssuer.expectedClientIds.includes(e.claims.client_id)&&Y("ID-JAG client_id is not allowed for this issuer.")}n(Is,"assertClientBinding");function Ss(e){e.cnf!==void 0&&Y("ID-JAG cnf-bound assertions require DPoP support.")}n(Ss,"assertProofOfPossessionNotDeferred");function Cs(e){let t=Math.floor(e.now.getTime()/1e3)+vs;e.claims.iat>t&&Y("ID-JAG iat must not be in the future.")}n(Cs,"assertIssuedAtNotInFuture");async function As(e){let t;try{t=Hm(e.assertion)}catch{Y("ID-JAG assertion is malformed.")}t.typ!==Ar&&Y('ID-JAG header typ must be "oauth-id-jag+jwt".');let r;try{r=bs(zm(e.assertion))}catch(s){if(s instanceof m)throw s;Y("ID-JAG assertion is malformed.")}let o=Ge(e.requestUrl,e.requestHeaders),i=[o];e.requestedResource!==void 0&&e.requestedResource!==o&&i.push(e.requestedResource);let a=Zm(e.config,r.iss);i.includes(r.iss)&&Y("ID-JAG issuer must be different from the gateway."),Is({claims:r,trustedIssuer:a,authenticatedClientId:e.authenticatedClientId,clientAuth:e.clientAuth}),Ss(r),Cs({claims:r,now:e.now});let c;try{let s=jm(new URL(a.jwksUrl)),{payload:u}=await Bm(e.assertion,s,{issuer:a.issuer,audience:i,currentDate:e.now,clockTolerance:vs,typ:Ar});c=bs(u)}catch(s){e.context?.log.warn({event:"oauth_id_jag_verification_failed",issuer:a.issuer,failureKind:Fm(s)},"OAuth ID-JAG assertion verification failed"),Y("ID-JAG assertion verification failed.")}return Is({claims:c,trustedIssuer:a,authenticatedClientId:e.authenticatedClientId,clientAuth:e.clientAuth}),Ss(c),Cs({claims:c,now:e.now}),{claims:c,trustedIssuer:a,subjectId:ko({issuer:c.iss,subject:c.sub,gatewayIssuer:o,subjectMapping:a.subjectMapping,tenant:c.tenant}),grantedAuthorizationDetails:Km({authorizationDetails:c.authorization_details,allowedTypes:e.config.idJag.enabled?e.config.idJag.authorizationDetailsTypesAllowed:void 0})}}n(As,"verifyIdJagAssertion");var Xm=new Set(["authorization_code","refresh_token",be]),Qm=1e4,ef=32*1024,tf=2,rf=3600,kn=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()}),nf=d.discriminatedUnion("grant_type",[kn.extend({grant_type:d.literal("authorization_code"),code:d.string().min(1),redirect_uri:d.string().min(1),code_verifier:Be,resource:d.url().optional(),scope:d.literal(M).optional()}),kn.extend({grant_type:d.literal("refresh_token"),refresh_token:d.string().min(1),resource:d.url().optional(),scope:d.literal(M).optional()}),kn.extend({grant_type:d.literal(be),assertion:d.string().min(1),resource:d.url().optional(),scope:d.literal(M).optional(),authorization_details:d.string().min(1).optional()})]);function of(e){if(typeof e!="object"||e===null)return;let t=e.grant_type;if(t!==void 0&&(typeof t!="string"||!Xm.has(t)))throw new m("unsupported_grant_type",`Grant type "${typeof t=="string"?t:""}" is not supported.`)}n(of,"assertSupportedGrantType");var af=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()}),sf=d.object({keys:d.array(d.record(d.string(),d.unknown())).min(1)}).passthrough();function ks(){return L().gateway.accessTokenTtlSeconds}n(ks,"readAccessTokenTtlSeconds");function cf(){return L().gateway.refreshTokenTtlSeconds}n(cf,"readRefreshTokenTtlSeconds");function xs(e,t){let r=ks(),o=Math.max(1,Math.floor((new Date(t).getTime()-e.getTime())/1e3)),i=Math.min(r,o);return{expiresAt:I(de(e,i)),expiresIn:i}}n(xs,"calculateAccessTokenExpiresAt");function df(e){let t=e.claimedResource===void 0?[]:Array.isArray(e.claimedResource)?e.claimedResource:[e.claimedResource];if(e.requestedResource!==void 0){if(t.length>0&&!t.includes(e.requestedResource))throw new m("invalid_target","Token request resource must match the ID-JAG resource.");return e.requestedResource}if(t.length===0)throw new m("invalid_target","resource is required for the ID-JAG JWT bearer grant.");if(t.length!==1)throw new m("invalid_target","ID-JAG resource arrays require a token request resource.");return t[0]}n(df,"readIdJagResource");function uf(e){if(e.claimAuthorizationDetails===void 0)return;let t=(e.grantedAuthorizationDetails??[]).filter(r=>r.locations?.includes(e.resource)===!0);if(t.length===0)throw new m("invalid_grant","ID-JAG authorization_details must authorize the requested resource.");return t}n(uf,"readIdJagGrantedAuthorizationDetails");function lf(e){if(e.claimScope?.split(/\s+/).includes(M)===!0||(e.grantedAuthorizationDetails?.length??0)>0)return M;if(e.claimScope===void 0)throw new m("invalid_grant",`ID-JAG must include ${M} scope or matching authorization_details.`);if(!e.claimScope.split(/\s+/).includes(M))throw new m("invalid_grant",`ID-JAG scope must include ${M}.`);return M}n(lf,"readIdJagGrantedScope");function pf(e){if(e!==void 0&&e.get("dpop")!==null)throw new m("invalid_request","DPoP proofs are not supported for the ID-JAG JWT bearer grant.")}n(pf,"assertNoDpopProofForIdJag");function Ts(e){if(!e?.startsWith("Basic "))return{};let t;try{t=atob(e.slice(6))}catch{throw new m("invalid_client","Malformed HTTP Basic client authentication.")}let r=t.indexOf(":");if(r<0)throw new m("invalid_client","Malformed HTTP Basic client authentication.");try{return{clientId:decodeURIComponent(t.slice(0,r)),clientSecret:decodeURIComponent(t.slice(r+1))}}catch{throw new m("invalid_client","Malformed HTTP Basic client authentication.")}}n(Ts,"readBasicClientSecret");function Us(e){if(e.basicClientId!==void 0&&e.bodyClientId!==void 0&&e.basicClientId!==e.bodyClientId)throw new m("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=Vm(e.clientAssertion);if(typeof r.iss=="string"&&typeof r.sub=="string"&&r.iss===r.sub)return r.iss}catch{throw new m("invalid_client","Malformed private_key_jwt client assertion.")}throw new m("invalid_client","private_key_jwt client assertion must identify the client with matching iss and sub claims.")}throw new m("invalid_client","Client authentication or client_id is required.")}n(Us,"resolveAuthenticatedClientId");function mf(e){if(e.basicClientSecret!==void 0&&e.bodyClientSecret!==void 0)throw new m("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(mf,"resolveClientSecretInput");function ff(e){return e.clientAssertion!==void 0||e.clientAssertionType!==void 0}n(ff,"hasClientAssertion");function hf(e){if(e.requestUrl===void 0)throw new m("invalid_request","Request URL is required for private_key_jwt client authentication.");let t=new URL(H().actionPath(e.pathname),q(e.requestUrl,e.requestHeaders));return t.search="",t.hash="",t.toString()}n(hf,"buildEndpointAudience");function gf(e){return e instanceof Et.JWTExpired?"expired":e instanceof Et.JWTClaimValidationFailed?"claim":e instanceof Et.JWSSignatureVerificationFailed?"signature":e instanceof Et.JWKSNoMatchingKey?"jwks_no_match":e instanceof Et.JWTInvalid?"invalid":e instanceof d.ZodError?"schema":"other"}n(gf,"readJwtFailureKind");async function yf(e){let{response:t,json:r}=await ui(e.jwksUri,{headers:{accept:"application/json"}},{context:e.context,maxRedirects:tf,maxResponseBytes:ef,timeoutMs:Qm});if(!t.ok)throw new m("invalid_client","Client JWKS could not be fetched.");return sf.parse(r)}n(yf,"fetchClientJwks");async function _f(e){if(e.clientAssertionType!==Zt||e.clientAssertion===void 0)throw new m("invalid_request","private_key_jwt client authentication requires a JWT bearer client_assertion and client_assertion_type.");let t=ue.parse(e.clientId),r=await _r(t,e.now);if(r.metadata.token_endpoint_auth_method!=="private_key_jwt")throw new m("invalid_client","Client is not registered for private_key_jwt authentication.");let o=r.metadata.jwks_uri;if(o===void 0)throw new m("invalid_client","Client JWKS URI is required for private_key_jwt authentication.");let i=hf({requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,pathname:e.endpointPathname});try{let a=await yf({jwksUri:o,context:e.context}),{payload:c}=await Ym(e.clientAssertion,Wm(a),{issuer:t,subject:t,audience:i,currentDate:e.now}),s=Math.floor(e.now.getTime()/1e3)+rf;if(typeof c.exp!="number"||c.exp>s)throw new m("invalid_client","Client authentication failed.")}catch(a){throw e.context?.log.warn({event:"oauth_private_key_jwt_client_auth_failed",clientId:t,failureKind:gf(a)},"OAuth private_key_jwt client authentication failed"),new m("invalid_client","Client authentication failed.")}return{method:"private_key_jwt",clientId:t}}n(_f,"verifyPrivateKeyJwtClientAssertion");async function wf(e){let t=ue.parse(e.clientId);if(qo(t))throw new m("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 k(e.clientSecret)}}n(wf,"buildRuntimeHttpClientAuth");async function Ps(e){if(ff({clientAssertion:e.clientAssertion,clientAssertionType:e.clientAssertionType})){if(e.basicClientSecret!==void 0||e.bodyClientSecret!==void 0)throw new m("invalid_request","Use only one client authentication method per request.");return _f(e)}let t=mf({basicClientSecret:e.basicClientSecret,bodyClientSecret:e.bodyClientSecret});return wf({clientId:e.clientId,...t})}n(Ps,"resolveRuntimeHttpClientAuth");async function Es(e){of(e.body);let t=nf.parse(e.body),r=Ts(e.authorizationHeader),o=Us({basicClientId:r.clientId,bodyClientId:t.client_id,clientAssertion:t.client_assertion}),i=new Date,a=await Ps({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 Rf({parsed:t,clientId:o,clientAuth:a,now:i,requestUrl:e.requestUrl,requestHeaders:e.requestHeaders,context:e.context})}n(Es,"exchangeDownstreamToken");async function Rf(e){if(e.parsed.grant_type==="authorization_code"){it(e.parsed.redirect_uri,"invalid_request"),at(e.parsed.scope),e.parsed.resource!==void 0&&Me(e.requestUrl??e.parsed.resource,e.parsed.resource,e.requestHeaders);let s=le(),u=le(),p=I(de(e.now,cf())),f=xs(e.now,p),w=await b().exchangeAuthorizationCode({clientAuth:e.clientAuth,codeHash:await k(e.parsed.code),redirectUri:e.parsed.redirect_uri,resource:e.parsed.resource,codeChallenge:await Yt(e.parsed.code_verifier),currentRefreshTokenHash:await k(s),accessTokenHash:await k(u),grantExpiresAt:p,accessTokenExpiresAt:f.expiresAt,now:I(e.now)});if(w.kind==="invalid_client")throw new m("invalid_client","Client authentication failed.");if(w.kind==="resource_mismatch")throw new m("invalid_target","Token request resource must match the authorization code resource.");if(w.kind!=="exchanged")throw new m("invalid_grant","Authorization code is invalid, expired, already used, or failed binding validation.");return e.context&&v(e.context,{eventType:S.MCP_OAUTH_TOKEN_ISSUED,outcome:"success",attributes:{clientId:e.clientId,grantType:"authorization_code"}}),{access_token:u,token_type:"Bearer",expires_in:f.expiresIn,refresh_token:s,scope:w.grant.scope,resource:w.grant.resource}}if(e.parsed.grant_type===be){at(e.parsed.scope),pf(e.requestHeaders);let s=await As({assertion:e.parsed.assertion,authenticatedClientId:e.clientId,clientAuth:e.clientAuth,requestUrl:e.requestUrl??e.parsed.resource??"",requestHeaders:e.requestHeaders,requestedResource:e.parsed.resource,now:e.now,context:e.context,config:L()}),u=df({claimedResource:s.claims.resource,requestedResource:e.parsed.resource}),p=Me(e.requestUrl??u,u,e.requestHeaders),f=uf({claimAuthorizationDetails:s.claims.authorization_details,grantedAuthorizationDetails:s.grantedAuthorizationDetails,resource:u}),w=lf({claimScope:s.claims.scope,grantedAuthorizationDetails:f}),U=le(),y=I(new Date(s.claims.exp*1e3)),P=xs(e.now,y),x=await b().issueAccessTokenForIdJag({clientAuth:e.clientAuth,accessTokenHash:await k(U),subjectId:s.subjectId,resource:u,operationId:p.operationId,scope:w,authorizationDetails:f,accessTokenExpiresAt:P.expiresAt,now:I(e.now),idJag:{issuer:s.claims.iss,jti:s.claims.jti,tenant:s.claims.tenant,expiresAt:y}});if(x.kind==="invalid_client")throw new m("invalid_client","Client authentication failed.");if(x.kind==="resource_mismatch")throw new m("invalid_target","Token request resource must match the ID-JAG resource.");return e.context&&v(e.context,{eventType:S.MCP_OAUTH_TOKEN_ISSUED,outcome:"success",attributes:{clientId:e.clientId,grantType:"jwt-bearer"}}),{access_token:U,token_type:"Bearer",expires_in:P.expiresIn,scope:x.grant.scope,resource:x.grant.resource,...f===void 0?{}:{authorization_details:f}}}at(e.parsed.scope),e.parsed.resource!==void 0&&Me(e.requestUrl??e.parsed.resource,e.parsed.resource,e.requestHeaders);let t=await k(e.parsed.refresh_token),r=e.parsed.refresh_token,o=le(),i=I(de(e.now,ks())),a=await b().refreshToken({clientAuth:e.clientAuth,currentRefreshTokenHash:t,nextRefreshTokenHash:t,accessTokenHash:await k(o),resource:e.parsed.resource,accessTokenExpiresAt:i,now:I(e.now)});if(a.kind==="invalid_client")throw new m("invalid_client","Client authentication failed.");if(a.kind==="resource_mismatch")throw new m("invalid_target","Token request resource must match the refresh token grant resource.");if(a.kind!=="rotated")throw new m("invalid_grant","Refresh token is invalid, expired, or revoked.");Me(e.requestUrl??a.grant.resource,a.grant.resource,e.requestHeaders);let c=a.accessToken.expiresAt;return e.context&&v(e.context,{eventType:S.MCP_OAUTH_TOKEN_ISSUED,outcome:"success",attributes:{clientId:e.clientId,grantType:"refresh_token"}}),{access_token:o,token_type:"Bearer",expires_in:Math.max(1,Math.floor((new Date(c).getTime()-e.now.getTime())/1e3)),refresh_token:r,scope:a.grant.scope,resource:a.grant.resource}}n(Rf,"exchangeDownstreamTokenWithRuntimeHttp");async function Os(e){let t=af.parse(e.body),r=Ts(e.authorizationHeader),o=Us({basicClientId:r.clientId,bodyClientId:t.client_id,clientAssertion:t.client_assertion}),i=new Date;if((await b().revokeOAuthToken({clientAuth:await Ps({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 k(t.token),now:I(i)})).kind==="invalid_client")throw new m("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:S.MCP_OAUTH_TOKEN_REVOKED,outcome:"success",attributes:{clientId:o,...t.token_type_hint===void 0?{}:{tokenTypeHint:t.token_type_hint}}})}n(Os,"revokeDownstreamToken");var bf=64*1024,If=16*1024,Sf="text/html; charset=utf-8";function Cf(e){let t={};for(let[r,o]of e.entries())t[r]=o;return t}n(Cf,"formDataToObject");async function vf(e){return ga(e,{maxBytes:bf,label:"Request body"})}n(vf,"readJsonBody");async function Un(e){return Cf(await ya(e,{maxBytes:If,label:"Request body"}))}n(Un,"readFormBody");async function Ms(e,t,r){let o=ce(r),i=r instanceof d.ZodError?xe(r):void 0,a={code:o??(r instanceof d.ZodError?"invalid_request":"internal_server_error")};return i!==void 0&&(a.detail=i),Lt(e,t,a)}n(Ms,"handleProblem");function Ds(e){return e?.requestId}n(Ds,"readBrowserRequestId");function js(e){if(!(e instanceof h))return;let t=e.extensionMembers?.[Ne];return typeof t=="string"?t:void 0}n(js,"readUpstreamHtmlError");function qs(e,t){let r=e.extensionMembers?.[t];return typeof r=="string"?r:void 0}n(qs,"readRuntimeErrorExtensionString");function Af(e,t){let r=e.extensionMembers?.[t];return typeof r=="number"?r:void 0}n(Af,"readRuntimeErrorExtensionNumber");function xf(e){try{return new URL(e.url).pathname}catch{return}}n(xf,"readBrowserRequestPath");function De(e){let t={code:e.code,requestId:e.requestId,routePath:xf(e.request),underlyingError:e.underlyingError};return e.error instanceof h&&(t.httpStatus=Af(e.error,_e),t.contentType=qs(e.error,Le),t.upstreamUrl=qs(e.error,we)),t}n(De,"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 kf(e,t){return e.errorCode!=="invalid_client"?{}:t.includeInvalidClientChallenge===!1?{}:{"WWW-Authenticate":'Basic realm="OAuth"'}}n(kf,"readOAuthProtocolHeaders");function Tf(e,t){let r=re("internal_server_error");return Ot({error:e.errorCode,errorDescription:e.errorCode==="server_error"?r.publicDetail:e.message,status:e.status,headers:kf(e,t)})}n(Tf,"oauthProtocolErrorResponse");function Tn(e){return e.issues[0]?.path.includes("resource")===!0?"invalid_target":"invalid_request"}n(Tn,"readZodOAuthErrorCode");function Uf(e){let t={error:Tn(e)},r=xe(e);return r!==void 0&&(t.errorDescription=r),Ot(t)}n(Uf,"oauthZodErrorResponse");function Pf(e){let t=ce(e);if(t===void 0)return;let r=re(t);if(r.oauthError===void 0)return;let o={error:r.oauthError,status:Of(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(Pf,"oauthGatewayProblemResponse");function Ef(){let t={error:"server_error",status:500,errorDescription:re("internal_server_error").publicDetail};return Ot(t)}n(Ef,"oauthFallbackErrorResponse");function Of(e){switch(e){case"invalid_client":return 401;case"server_error":return 500;default:return 400}}n(Of,"readOAuthStatus");function Pn(e,t={}){return e instanceof Ae?Bs(e):e instanceof m?Tf(e,t):e instanceof d.ZodError?Uf(e):Pf(e)??Ef()}n(Pn,"oauthProblemResponse");function En(e,t,r){let o=nt(e.url),i=Ds(t);if(r instanceof Ae)return Bs(r);if(r instanceof m){let s=re("internal_server_error");return ie({host:o,kind:qf(r.errorCode),title:"Authorization failed",detail:r.errorCode==="server_error"?s.publicDetail:r.message,developerDetail:r.errorCode==="server_error"?s.publicDetail:r.message,code:r.errorCode,diagnostic:De({request:e,requestId:i,code:r.errorCode,underlyingError:r.errorCode==="server_error"?s.publicDetail:r.message,error:r}),requestId:i,status:r.status})}if(r instanceof d.ZodError)return ie({host:o,kind:"invalid_request",detail:xe(r)??"The authorization request was invalid.",developerDetail:xe(r)??"The authorization request was invalid.",code:Tn(r),diagnostic:De({request:e,requestId:i,code:Tn(r),underlyingError:xe(r)??"The authorization request was invalid.",error:r}),requestId:i});let a=ce(r);if(a!==void 0){let s=re(a);return ie({host:o,kind:Hs(a),detail:s.publicDetail,developerDetail:s.status>=500||!(r instanceof Error)?s.publicDetail:r.message,code:a,diagnostic:De({request:e,requestId:i,code:a,underlyingError:s.status>=500||!(r instanceof Error)?s.publicDetail:r.message,error:r}),requestId:i,upstreamHtml:js(r),status:s.status})}let c=re("internal_server_error");return ie({host:o,kind:"internal_error",detail:c.publicDetail,developerDetail:c.publicDetail,code:"server_error",diagnostic:De({request:e,requestId:i,code:"server_error",underlyingError:c.publicDetail,error:r}),requestId:i,status:c.status})}n(En,"browserOAuthProblemResponse");function zs(e,t,r){let o=nt(e.url),i=Ds(t),a=ce(r);if(a!==void 0){let s=re(a);return ie({host:o,kind:Hs(a),detail:s.publicDetail,developerDetail:s.status>=500||!(r instanceof Error)?s.publicDetail:r.message,code:a,diagnostic:De({request:e,requestId:i,code:a,underlyingError:s.status>=500||!(r instanceof Error)?s.publicDetail:r.message,error:r}),requestId:i,upstreamHtml:js(r),status:s.status})}if(r instanceof d.ZodError)return ie({host:o,kind:"invalid_request",detail:xe(r)??"The authorization request was invalid.",developerDetail:xe(r)??"The authorization request was invalid.",code:"invalid_request",diagnostic:De({request:e,requestId:i,code:"invalid_request",underlyingError:xe(r)??"The authorization request was invalid.",error:r}),requestId:i});let c=re("internal_server_error");return ie({host:o,kind:"internal_error",detail:c.publicDetail,developerDetail:c.publicDetail,code:"internal_server_error",diagnostic:De({request:e,requestId:i,code:"internal_server_error",underlyingError:c.publicDetail,error:r}),requestId:i,status:c.status})}n(zs,"browserGatewayProblemResponse");function qf(e){return e==="server_error"?"internal_error":"invalid_request"}n(qf,"readOAuthBrowserErrorKind");function Hs(e){if(re(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(Hs,"readGatewayBrowserErrorKind");function he(e,t,r){let o={event:t},i=!1;if(r instanceof m)o.oauthError=r.errorCode,o.status=r.status,N(o,"error",r);else if(r instanceof Ae)o.oauthError=r.errorCode,N(o,"error",r);else if(r instanceof d.ZodError){o.code="invalid_request",N(o,"error",r);let a=r.issues[0];a&&(o.zodPath=a.path.join("."))}else{let a=ce(r);if(a!==void 0){let c=re(a);o.code=a,o.status=c.status,c.oauthError!==void 0&&(o.oauthError=c.oauthError),i=c.status>=500||c.oauthError==="server_error",N(o,"error",r)}else i=!0,N(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(he,"logUnexpectedOAuthHandlerError");function Bs(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(Bs,"downstreamAuthorizeRedirectErrorResponse");function xe(e){let t=e.issues[0];if(!t)return;let r=t.path.join(".");return r?`${r}: ${t.message}`:t.message}n(xe,"formatZodErrorDetail");function Mf(e,t){let r={event:"browser_login_callback_failed",code:ce(t)??"invalid_request"};N(r,"error",t),e.log.warn(r,"Browser login callback failed; client received a connection-failure page")}n(Mf,"logBrowserLoginCallbackFailure");function Ls(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(Ls,"redirectResultResponse");function Rr(e){if(e.kind==="setup_page"){let t=new Headers({"content-type":Sf,"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 Ls(e)}n(Rr,"authorizeResultResponse");async function Ns(e,t){try{return Response.json(Co(e.url,e.headers))}catch(r){return he(t,"oauth_authorization_server_metadata_failed",r),Ms(e,t,r)}}n(Ns,"authorizationServerMetadataHandler");async function Js(e,t){try{let r=Or(e.params.routePath);return Response.json(vo({operationId:r.operationId,requestUrl:e.url,requestHeaders:e.headers}))}catch(r){return he(t,"oauth_authorization_server_metadata_failed",r),Ms(e,t,r)}}n(Js,"scopedAuthorizationServerMetadataHandler");async function Gs(e,t){try{let r=await Va(await vf(e)),o=r.client_id,i=r.client_name,a=r.redirect_uris.length,c=r.token_endpoint_auth_method;return t.log.info({event:"oauth_dcr_client_registered",clientId:o,clientName:i,redirectUriCount:a,tokenEndpointAuthMethod:c},"OAuth Dynamic Client Registration completed"),v(t,{eventType:S.MCP_OAUTH_CLIENT_REGISTERED,outcome:"success",clientName:i,attributes:{clientId:o,redirectUriCount:a,tokenEndpointAuthMethod:c}}),Response.json(r,{status:201,headers:{"cache-control":"no-store"}})}catch(r){return he(t,"oauth_register_failed",r),Pn(r)}}n(Gs,"registerHandler");async function Fs(e,t){try{return Rr(await xn(e,{context:t}))}catch(r){return he(t,"oauth_authorize_failed",r),En(e,t,r)}}n(Fs,"authorizeHandler");async function $s(e,t){try{let r=Or(e.params.routePath);return Rr(await xn(e,{operationId:r.operationId,context:t}))}catch(r){return he(t,"oauth_authorize_scoped_failed",r),En(e,t,r)}}n($s,"scopedAuthorizeHandler");async function Zs(e,t){try{let r=await _s(e,{context:t});return t.log.info({event:"browser_login_callback_completed",resultKind:r.kind},"Browser login callback completed; consent setup rendered"),Rr(r)}catch(r){return Mf(t,r),zs(e,t,r)}}n(Zs,"callbackHandler");async function Ks(e,t){try{return Ls(await ws(e))}catch(r){return he(t,"oauth_dev_login_failed",r),En(e,t,r)}}n(Ks,"devLoginHandler");async function Ws(e,t){try{if(!["GET","POST"].includes(e.method))return new Response(null,{status:405,headers:{allow:"GET, POST"}});let r=await Rs({request:e,body:e.method==="POST"?await Un(e):void 0,context:t});return Rr(r)}catch(r){return he(t,"oauth_setup_failed",r),zs(e,t,r)}}n(Ws,"setupHandler");async function Vs(e,t){try{return Response.json(await Es({body:await Un(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 he(t,"oauth_token_failed",r),Pn(r)}}n(Vs,"tokenHandler");async function Ys(e,t){try{return await Os({body:await Un(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 he(t,"oauth_revoke_failed",r),Pn(r)}}n(Ys,"revokeHandler");function Xs(e){return C`<p data-gateway-error-code="${e.code}">${e.body}</p>`}n(Xs,"renderBrowserResult");var Df="text/html; charset=utf-8",jf="none";function zf(e){let t=Kr(e.host);return rt({title:e.title,iconHref:t,styles:tt,headerIcon:wr({iconHref:t,fallbackIconHref:nr}),heading:e.title,subhead:"",body:Xs({body:e.body,code:e.code??jf}),footer:""})}n(zf,"browserResultHtml");function Hf(e,t=200){return new Response(et(e),{status:t,headers:{"content-type":Df,"cache-control":"no-store","referrer-policy":"no-referrer","x-frame-options":"DENY"}})}n(Hf,"browserResultResponse");function Qs(e){return Hf(zf(e))}n(Qs,"browserConnectionSuccessResponse");function br(e,t,r={}){let o=ro(t);return ie({host:e,kind:Bf(t),detail:o.body,developerDetail:r.developerDetail,code:t,diagnostic:r.diagnostic,upstreamHtml:r.upstreamHtml})}n(br,"browserConnectionFailureResponse");function Bf(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(Bf,"readCallbackFailureBrowserErrorKind");var Lf={connect:"Connect",callback_authorization_code:"Callback",callback_provider_error:"Callback",callback_invalid:"Callback",client_metadata:"Client metadata"},ec=Symbol("upstream-request");function qt(e,t){Object.defineProperty(e,ec,{configurable:!0,value:t})}n(qt,"setUpstreamRequestContext");function Nf(e){let t=e[ec];if(!t)throw new Q("Upstream request context has not been set");return t}n(Nf,"readUpstreamRequestContext");function Jf(e,t){return t.some(r=>r===e)}n(Jf,"requestContextMatchesKind");function Gf(e){return typeof e=="string"?[e]:e}n(Gf,"toExpectedKinds");function Mt(e,t){let r=Nf(e),o=Gf(t);if(!Jf(r.kind,o)){let i=Lf[o[0]];throw new Q(`${i} request context has not been set`)}return r}n(Mt,"requireUpstreamRequestContext");function je(e){if(typeof e=="string"&&e.length!==0)return e}n(je,"readOptionalQueryString");function Ff(e,t){let r=e.params[t];if(typeof r!="string"||r.length===0)throw new Q(`Validated path parameter ${t} is missing`);return $f(r,t)}n(Ff,"requirePathString");function $f(e,t){try{return decodeURIComponent(e)}catch(r){throw new h({message:`Path parameter "${t}" must be valid URL encoding.`,extensionMembers:{[g]:"invalid_request"}},{cause:r})}}n($f,"decodePathString");function Zf(e){let t=je(e);return t?Nt.parse(t):void 0}n(Zf,"readOptionalOperationId");function Kf(e){let t=ee().connectionsById.get(e);if(t!==void 0)return t.authProfileId;throw new h({message:`No upstream connection is registered for ${e}.`,extensionMembers:{[g]:"unknown_upstream_server"}})}n(Kf,"readRegisteredAuthProfileId");function Wf(e){let t=Zf(e);if(!t)throw new h({message:"operationId query parameter is required.",extensionMembers:{[g]:"invalid_request"}});return t}n(Wf,"readRequiredOperationId");async function Vf(e,t){let r=pr(t,Wf(e.query.operationId));if(r.authMode==="id-jag")throw new h({message:"This upstream uses XAA / ID-JAG and does not support browser OAuth connection flows.",extensionMembers:{[g]:"invalid_request"}});let o=e.query.redirect==="true",i=je(e.query.browserTicket);if(e.user){if(i)throw new h({message:"Use either an authenticated gateway request or a browser connect ticket, not both.",extensionMembers:{[g]:"invalid_request"}});let s=Te(e.user,e.url),u={kind:"connect",...Qe(r,s.subjectId),redirect:o},p=uo(je(e.query.returnTo));return p!==void 0&&(u.returnTo=p),u}if(!i)throw new h({message:"Authentication is required to start the upstream connection flow.",extensionMembers:{[g]:"authentication_required"}});let a=await Ai(i);if(a.ownerMode!==r.ownerMode||a.upstreamServerId!==r.upstreamServerId||a.authProfileId!==r.authProfileId||a.operationId!==r.operationId)throw new h({message:"Browser connect ticket did not match the requested upstream flow",extensionMembers:{[g]:"oauth_callback_mismatch"}});await xi(a);let c=Ft(a);switch(r.authMode){case"shared-oauth":{if(c.mode!=="shared")throw new h({message:"Browser connect ticket did not match the requested upstream flow",extensionMembers:{[g]:"oauth_callback_mismatch"}});let s={kind:"connect",...r,authMode:"shared-oauth",ownerMode:"shared",owner:c,initiatedBySubjectId:a.initiatedBySubjectId,redirect:o};return a.returnTo!==void 0&&(s.returnTo=a.returnTo),s}case"user-oauth":{if(c.mode!=="user")throw new h({message:"Browser connect ticket did not match the requested upstream flow",extensionMembers:{[g]:"oauth_callback_mismatch"}});let s={kind:"connect",...r,authMode:"user-oauth",ownerMode:"user",owner:c,initiatedBySubjectId:a.initiatedBySubjectId,redirect:o};return a.returnTo!==void 0&&(s.returnTo=a.returnTo),s}}}n(Vf,"resolveConnectContext");async function Yf(e,t,r){let o=io.parse(Ff(e,"connection"));switch(r){case"connect":qt(e,await Vf(e,o));return;case"callback":{let i=je(e.query.error);if(i){let s={kind:"callback_provider_error",upstreamServerId:o,error:i},u=je(e.query.error_description);u!==void 0&&(s.errorDescription=u),qt(e,s);return}let a=je(e.query.code),c=je(e.query.state);if(a&&c){qt(e,{kind:"callback_authorization_code",upstreamServerId:o,code:a,state:c});return}qt(e,{kind:"callback_invalid",upstreamServerId:o});return}case"client_metadata":qt(e,{kind:"client_metadata",upstreamServerId:o,authProfileId:Kf(o)});return}}n(Yf,"resolveUpstreamRequestInbound");async function Xf(e,t,r){try{await Yf(e,t,r);return}catch(o){let i=o instanceof h?o.extensionMembers?.[g]:void 0,a=o instanceof Error?o.message:void 0;switch(i){case"invalid_request":case"unknown_upstream_server":case"oauth_callback_mismatch":return ke.badRequest(e,t,{code:i,detail:a});case"authentication_required":return ke.unauthorized(e,t,{code:i,detail:a});default:throw o}}}n(Xf,"applyUpstreamRequestContext");function Ir(e,t){return n(async(o,i)=>{let a=await Xf(o,i,e);return a||t(o,i)},"wrapped")}n(Ir,"withUpstreamRequestContext");var Qf=["callback_authorization_code","callback_provider_error","callback_invalid"];function On(e){try{return new URL(e.url).pathname}catch{return}}n(On,"readBrowserRequestPath");function eh(e){return"cause"in e?e.cause:void 0}n(eh,"readErrorCause");function th(e){return e.stack?.split(`
49
+ `).slice(1,4).map(t=>t.trim()).join(" | ")}n(th,"readFirstStackFrame");function tc(e,t,r){r instanceof Error&&(e[`${t}Name`]=r.name,e[`${t}Message`]=r.message,e[`${t}StackFrame`]=th(r))}n(tc,"addErrorAttributes");function qn(e){if(!(e instanceof h))return;let t=e.extensionMembers?.[g];return Bt(t)?t:void 0}n(qn,"readRuntimeGatewayCode");function rc(e,t){let r=e.extensionMembers?.[t];return typeof r=="string"?r:void 0}n(rc,"readRuntimeErrorExtensionString");function rh(e,t){let r=e.extensionMembers?.[t];return typeof r=="number"?r:void 0}n(rh,"readRuntimeErrorExtensionNumber");function nh(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:S.MCP_AUTH_UPSTREAM_TOKEN_EXCHANGE_FAILED,outcome:"failure",upstreamServerName:r.upstreamServerId,reasonCode:"provider_access_denied",reasonClass:"auth",attributes:{error:r.error,errorDescription:r.errorDescription}}),br(o,"provider_access_denied",{developerDetail:r.errorDescription??r.error,diagnostic:{code:"provider_access_denied",requestId:t.requestId,routePath:On(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"),br(o,"oauth_state_invalid",{diagnostic:{code:"oauth_state_invalid",requestId:t.requestId,routePath:On(e),upstreamServerId:r.upstreamServerId}});case"callback_authorization_code":return r}}n(nh,"requireAuthorizationCallbackRequest");function oh(e,t){v(e,{eventType:S.MCP_AUTH_UPSTREAM_CALLBACK_RECEIVED,outcome:"success",upstreamServerName:t.upstreamServerId})}n(oh,"emitCallbackReceivedAnalyticsEvent");function ih(e,t){v(e,{eventType:S.MCP_AUTH_UPSTREAM_TOKEN_EXCHANGE_SUCCEEDED,outcome:"success",upstreamServerName:t.upstreamServerId,virtualServerName:t.operationId})}n(ih,"emitTokenExchangeSucceededAnalyticsEvent");function ah(e,t){if(t.returnTo){let r=t.returnOrigin??e.url;return Response.redirect(new URL(t.returnTo,r).toString(),302)}return Qs({host:nt(e.url),title:"Connection complete",body:"The upstream authorization flow completed successfully. You can return to your MCP client."})}n(ah,"buildSuccessfulCallbackResponse");function sh(e){let t={detail:e instanceof Error?e.message:void 0};return tc(t,"error",e),e instanceof Error&&tc(t,"cause",eh(e)),t}n(sh,"buildTokenExchangeFailureAttributes");function ch(e){v(e.context,{eventType:S.MCP_AUTH_UPSTREAM_TOKEN_EXCHANGE_FAILED,outcome:"failure",upstreamServerName:e.callbackRequest.upstreamServerId,reasonCode:qn(e.error)??"token_exchange_failed",reasonClass:"auth",errorType:e.error instanceof Error?e.error.name:"unknown",attributes:sh(e.error)})}n(ch,"emitTokenExchangeFailedAnalyticsEvent");function dh(e){let t=e.error,r=qn(t),o=to(r)?r:"upstream_token_exchange_failed",i={code:o,requestId:e.context.requestId,routePath:On(e.request),upstreamServerId:e.callbackRequest.upstreamServerId,underlyingError:t instanceof Error?t.message:void 0,...t instanceof h?{httpStatus:rh(t,_e),contentType:rc(t,Le),upstreamUrl:rc(t,we)}:{}};return br(e.host,o,{developerDetail:t instanceof Error?t.message:void 0,diagnostic:i,upstreamHtml:uh(t)})}n(dh,"tokenExchangeFailureResponse");function uh(e){if(!(e instanceof h))return;let t=e.extensionMembers?.[Ne];return typeof t=="string"?t:void 0}n(uh,"readUpstreamHtmlError");async function Mn(e,t){let r=Mt(e,Qf),o=nt(e.url),i=nh(e,t,r,o);if(i instanceof Response)return i;oh(t,i);try{let a=await aa({request:e,callbackRequest:i});return ih(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"),ah(e,a)}catch(a){let c={event:"upstream_oauth_token_exchange_failed",code:qn(a)??"upstream_token_exchange_failed",upstreamServerId:i.upstreamServerId};return N(c,"error",a),t.log.warn(c,"Upstream OAuth token exchange failed; user shown connection-failure page"),ch({context:t,callbackRequest:i,error:a}),dh({request:e,context:t,host:o,callbackRequest:i,error:a})}}n(Mn,"callbackHandler");function lh(e){return(e instanceof Error?e.message:void 0)??"The requested upstream client metadata document was not found."}n(lh,"clientMetadataProblemDetail");async function nc(e,t){let r=Mt(e,"connect"),o=await ia({request:e,connectRequest:r});if(v(t,{eventType:S.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 dr({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(nc,"connectHandler");async function oc(e,t){let r=Mt(e,"client_metadata");try{let o=q(e.url,e.headers),i=Mi(o,r.upstreamServerId,r.authProfileId);return Response.json(i)}catch(o){if(!(o instanceof B))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"),ke.notFound(e,t,{code:"not_found",detail:lh(o)})}}n(oc,"oauthClientMetadataHandler");function ph(e,t){return e.mount==="root"?e.path:t.actionPath(e.path)}n(ph,"resolveInternalRoutePath");var mh={"access-control-allow-origin":"*","access-control-allow-methods":"GET, OPTIONS","access-control-allow-headers":"content-type, authorization","access-control-max-age":"86400"};function fh(){return new Response(null,{status:204,headers:mh})}n(fh,"buildWellKnownPreflightResponse");function hh(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(hh,"withWellKnownCorsHeaders");function Dn(e){return async(t,r)=>t.method==="OPTIONS"?fh():hh(await e(t,r))}n(Dn,"wrapWellKnownHandler");var sc=[{routeName:"oauth_as_metadata",mount:"root",path:"/.well-known/oauth-authorization-server",methods:["GET","OPTIONS"],handler:Dn(Ns),corsPolicy:"anything-goes"},{routeName:"oauth_as_metadata_scoped",mount:"root",path:"/.well-known/oauth-authorization-server/:routePath*",methods:["GET","OPTIONS"],handler:Dn(Js),corsPolicy:"anything-goes"},{routeName:"oauth_protected_resource_metadata",mount:"root",path:"/.well-known/oauth-protected-resource/:routePath*",methods:["GET","OPTIONS"],handler:Dn(Ao),corsPolicy:"anything-goes"},{routeName:"oauth_register",mount:"action",path:"/oauth/register",methods:["POST"],handler:Gs},{routeName:"oauth_authorize",mount:"action",path:"/oauth/authorize",methods:["GET"],handler:Fs},{routeName:"oauth_authorize_scoped",mount:"action",path:"/oauth/authorize/:routePath*",methods:["GET"],handler:$s},{routeName:"oauth_callback",mount:"action",path:"/oauth/callback",methods:["GET"],handler:Zs},{routeName:"oauth_dev_login",mount:"action",path:"/oauth/dev-login",methods:["GET"],handler:Ks},{routeName:"oauth_setup",mount:"action",path:"/oauth/setup",methods:["GET","POST"],handler:Ws},{routeName:"oauth_token",mount:"action",path:"/oauth/token",methods:["POST"],handler:Vs},{routeName:"oauth_revoke",mount:"action",path:"/oauth/revoke",methods:["POST"],handler:Ys},{routeName:"upstream_client_metadata",mount:"action",path:"/.well-known/oauth-client/:connection",methods:["GET"],handler:Ir("client_metadata",oc)},{routeName:"upstream_connect",mount:"action",path:"/auth/connections/:connection/connect",methods:["GET"],handler:Ir("connect",nc)},{routeName:"upstream_callback",mount:"action",path:"/auth/connections/:connection/callback",methods:["GET"],handler:Ir("callback",Mn)}],gh=sc.filter(e=>!e.routeName.startsWith("upstream_")),yh=sc.filter(e=>e.routeName.startsWith("upstream_"));function _h(e){let t=ho({routes:e.routes,policies:e.policies,gateway:e.gateway});return go(t),t}n(_h,"initializeMcpGatewayConnectionRegistry");function wh(e){return[...e.byOperationId.values()].some(t=>t.downstreamOAuth!==void 0)}n(wh,"hasDownstreamOAuthRoutes");function Rh(e){return[...e.byOperationId.values()].some(t=>t.downstreamOAuth?.config.idJag.enabled===!0)}n(Rh,"hasIdJagDownstreamOAuth");function bh(e){let t=new Map;for(let o of e.byOperationId.values())o.downstreamOAuth&&t.set(o.downstreamOAuth.policyName,o.downstreamOAuth.config);if(t.size===1)return[...t.values()][0];let r=[...t.keys()].map(o=>`"${o}"`).join(", ");throw new B(`MCP gateway found multiple attached OAuth policies: ${r}. Multiple downstream MCP OAuth configs in one gateway are not supported yet; use one MCP OAuth policy across MCP routes or split these routes into separate gateways.`)}n(bh,"readSingletonDownstreamOAuthConfig");function Ih(e,t,r){let o=String(t.params.routePath??""),i=e.byRoutePath.get(bo(o));if(i===void 0)return;let a=i?.downstreamOAuth?.config;return a===void 0?Lt(t,r,{code:"not_found",detail:"The requested MCP route does not expose downstream OAuth."}):a}n(Ih,"readScopedDownstreamOAuthConfig");function Sh(e){return e.path==="/.well-known/oauth-authorization-server/:routePath*"||e.path==="/.well-known/oauth-protected-resource/:routePath*"||e.path==="/oauth/authorize/:routePath*"}n(Sh,"routeUsesScopedOAuthConfig");function ic(e,t,r){return async(o,i)=>{if(i.log.setLogProperties?.({requestId:i.requestId}),r){let u=await r(o,i);if(u instanceof Response)return u;u&&Xn(i,u)}let a=o.method==="OPTIONS",c=Date.now();a||i.log.info({event:`${e}_received`,method:o.method},`MCP gateway: ${e} received`);let s=await t(o,i);return a||i.log.info({event:`${e}_responded`,status:s.status,durationMs:Date.now()-c},`MCP gateway: ${e} responded`),s}}n(ic,"wrapInternalHandler");function ac(e,t,r,o){e.addPluginRoute({path:ph(t,r),methods:t.methods,handler:o,processors:[Nn],corsPolicy:t.corsPolicy??"none"})}n(ac,"addInternalRoute");function cc(e,t){let r=_h(t),o=wh(r),i=r.connectionsById.size>0,a,c=n(()=>(a===void 0&&(a=bh(r)),a),"readSingletonOAuthConfig");if(o){ae("plugin.mcp-gateway.downstream-oauth"),Rh(r)&&ae("plugin.mcp-gateway.downstream-oauth.id-jag");for(let s of gh){let u=Sh(s)?(p,f)=>Ih(r,p,f):c;ac(e,s,r.gateway,ic(s.routeName,s.handler,u))}}if(i){ae("plugin.mcp-gateway.upstream-auth");for(let s of r.connectionsById.values())ae(`plugin.mcp-gateway.upstream-auth.${s.authMode}`);for(let s of yh)ac(e,s,r.gateway,ic(s.routeName,s.handler))}}n(cc,"registerMcpGatewayInternalRoutes");var jn=class extends Bn{static{n(this,"McpGatewayPlugin")}#e;constructor(t={}){super(),ae("plugin.mcp-gateway"),this.#e=Qn(t)}registerRoutes(t){let r=t.parsedRouteData;r&&cc(t.router,{routes:r.routes,policies:r.policies,gateway:this.#e})}};var Ch=new TextDecoder;function vh(e){if(e)try{return JSON.parse(Ch.decode(e))}catch{return}}n(vh,"readBodyJson");function ge(e){return e&&typeof e=="object"?e:void 0}n(ge,"readRecord");function Dt(e,t){let r=ge(e)?.[t];return typeof r=="string"?r:void 0}n(Dt,"readStringProperty");function uc(e,t){let r=ge(e)?.[t];return typeof r=="number"?r:void 0}n(uc,"readNumberProperty");function dc(e,t){return uc(e,"code")??(t.status>=400?t.status:void 0)}n(dc,"readErrorCode");function lc(e){return Array.isArray(e)?e.map(lc).find(t=>t?.method):ge(e)}n(lc,"readJsonRpcMessage");function pc(e){let t=lc(vh(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:Dt(o,"name")};case"prompts/list":return{mcpMethod:r,capabilityType:"prompt"};case"prompts/get":return{mcpMethod:r,capabilityType:"prompt",capabilityName:Dt(o,"name")};case"resources/list":case"resources/templates/list":return{mcpMethod:r,capabilityType:"resource"};case"resources/read":{let i=Dt(o,"uri");return{mcpMethod:r,capabilityType:"resource",capabilityName:i,resourceUri:i}}default:return null}}n(pc,"buildBaseCapabilityInput");function mc(e){return e==="tools/list"||e==="prompts/list"||e==="resources/list"||e==="resources/templates/list"}n(mc,"isCapabilityListMethod");function Ah(e,t,r){let a=ge(r)?.[e==="resources/templates/list"?"resourceTemplates":t==="tool"?"tools":t==="prompt"?"prompts":"resources"];return Array.isArray(a)?a.length:void 0}n(Ah,"readItemCount");async function xh(e){try{return await e.clone().json()}catch{return}}n(xh,"readResponseJson");function fc(e){let t=pc(e);return!t||mc(t.mcpMethod)?null:{eventType:S.MCP_CAPABILITY_INVOKED,outcome:"success",...t}}n(fc,"buildCapabilityInvokedAnalyticsInput");async function hc(e,t){let r=pc(e);if(!r)return null;let o=ge(await xh(t)),i=ge(o?.error),a=ge(i?.data),c=o?.result,s=r.mcpMethod==="tools/call"&&ge(c)?.isError===!0;if(ge(a?.connectRequired))return{eventType:S.MCP_CAPABILITY_CONNECT_REQUIRED,outcome:"connect_required",...r,httpStatusCode:t.status,reasonCode:"connect_required",reasonClass:"auth",errorType:"connect_required",errorCode:uc(i,"code"),mcpErrorType:Dt(i,"message")};if(mc(r.mcpMethod)){let u=t.status>=400?void 0:Ah(r.mcpMethod,r.capabilityType,c);return{eventType:S.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:dc(i,t)}:{},...u===void 0?{}:{attributes:{itemCount:u}}}}return t.status>=400||i?{eventType:S.MCP_CAPABILITY_FAILED,outcome:"failure",...r,httpStatusCode:t.status,reasonCode:"upstream_capability_invocation_failed",reasonClass:"upstream",errorType:"capability_error",errorCode:dc(i,t),mcpErrorType:Dt(i,"message")}:{eventType:S.MCP_CAPABILITY_COMPLETED,outcome:s?"application_error":"success",...r,httpStatusCode:t.status,toolResultIsError:s,applicationError:s}}n(hc,"buildCapabilityFinalAnalyticsInput");var kh={Allow:"POST"};async function Th(e){try{return await e.clone().arrayBuffer()}catch{return}}n(Th,"readRequestBody");function gc(e){try{let t=yo(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(gc,"readRouteAnalyticsFields");function yc(e){return To(e.user,e.url,e.headers)?.subjectId}n(yc,"readRequestSubjectId");function Uh(e){let t=fc(e.requestBody);t&&v(e.context,{...t,...gc(e.context),httpMethod:e.request.method,subjectId:yc(e.request),transport:"http"})}n(Uh,"emitCapabilityInvokedAnalytics");async function Ph(e){let t=await hc(e.requestBody,e.response);t&&v(e.context,{...t,...gc(e.context),httpMethod:e.request.method,subjectId:yc(e.request),transport:"http",latencyMs:Date.now()-e.startedAt})}n(Ph,"emitCapabilityFinalAnalytics");async function Eh(e,t){if(ae("handler.mcp-gateway-proxy"),e.method==="GET")return ke.methodNotAllowed(e,t,{detail:"MCP Gateway routes support stateless Streamable HTTP requests over POST. Server-sent event GET streams are not supported."},kh);let r=Date.now(),o=await Th(e);Uh({context:t,request:e,requestBody:o});let i=await Wn(e,t);return await Ph({context:t,request:e,requestBody:o,response:i,startedAt:r}),i}n(Eh,"McpProxyHandler");export{kc as McpAuth0OAuthInboundPolicy,qr as McpCapabilityFilterInboundPolicy,_c as McpClerkOAuthInboundPolicy,wc as McpCognitoOAuthInboundPolicy,Rc as McpEntraOAuthInboundPolicy,jn as McpGatewayPlugin,bc as McpGoogleOAuthInboundPolicy,Ic as McpKeycloakOAuthInboundPolicy,Sc as McpLogtoOAuthInboundPolicy,Tc as McpOAuthInboundPolicy,Cc as McpOktaOAuthInboundPolicy,vc as McpOneLoginOAuthInboundPolicy,Ac as McpPingOAuthInboundPolicy,Eh as McpProxyHandler,un as McpTokenExchangeInboundPolicy,xc as McpWorkosOAuthInboundPolicy};
50
50
  //# sourceMappingURL=index.js.map