@worktif/runtime 0.3.0-edge.38 → 0.3.0-edge.39

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.
@@ -14,7 +14,7 @@
14
14
  "info": "runtime info"
15
15
  },
16
16
  "dependencies": {
17
- "@worktif/runtime": "^0.3.0-edge.38",
17
+ "@worktif/runtime": "^0.3.0-edge.39",
18
18
  "react": "^19.1.1",
19
19
  "react-dom": "^19.1.1",
20
20
  "react-router": "^7.7.1"
@@ -14,7 +14,7 @@
14
14
  "info": "runtime info"
15
15
  },
16
16
  "dependencies": {
17
- "@worktif/runtime": "^0.3.0-edge.38",
17
+ "@worktif/runtime": "^0.3.0-edge.39",
18
18
  "react": "^19.1.1",
19
19
  "react-dom": "^19.1.1",
20
20
  "react-router": "^7.7.1"
@@ -1,8 +1,8 @@
1
- "use strict";var Ge=Object.create;var h=Object.defineProperty;var We=Object.getOwnPropertyDescriptor;var Qe=Object.getOwnPropertyNames;var Ye=Object.getPrototypeOf,Ve=Object.prototype.hasOwnProperty;var N=(e,r)=>()=>(r||e((r={exports:{}}).exports,r),r.exports),je=(e,r)=>{for(var t in r)h(e,t,{get:r[t],enumerable:!0})},ee=(e,r,t,n)=>{if(r&&typeof r=="object"||typeof r=="function")for(let i of Qe(r))!Ve.call(e,i)&&i!==t&&h(e,i,{get:()=>r[i],enumerable:!(n=We(r,i))||n.enumerable});return e};var f=(e,r,t)=>(t=e!=null?Ge(Ye(e)):{},ee(r||!e||!e.__esModule?h(t,"default",{value:e,enumerable:!0}):t,e)),ke=e=>ee(h({},"__esModule",{value:!0}),e);var $=N(o=>{"use strict";Object.defineProperty(o,"__esModule",{value:!0});o.USE_PROXY=o.UNSUPPORTED_MEDIA_TYPE=o.UNPROCESSABLE_ENTITY=o.UNAUTHORIZED=o.TOO_MANY_REQUESTS=o.TEMPORARY_REDIRECT=o.SWITCHING_PROTOCOLS=o.SERVICE_UNAVAILABLE=o.SEE_OTHER=o.RESET_CONTENT=o.REQUESTED_RANGE_NOT_SATISFIABLE=o.REQUEST_URI_TOO_LONG=o.REQUEST_TOO_LONG=o.REQUEST_TIMEOUT=o.REQUEST_HEADER_FIELDS_TOO_LARGE=o.PROXY_AUTHENTICATION_REQUIRED=o.PROCESSING=o.PRECONDITION_REQUIRED=o.PRECONDITION_FAILED=o.PERMANENT_REDIRECT=o.PAYMENT_REQUIRED=o.PARTIAL_CONTENT=o.OK=o.NOT_MODIFIED=o.NOT_IMPLEMENTED=o.NOT_FOUND=o.NOT_ACCEPTABLE=o.NON_AUTHORITATIVE_INFORMATION=o.NO_CONTENT=o.NETWORK_AUTHENTICATION_REQUIRED=o.MULTIPLE_CHOICES=o.MULTI_STATUS=o.MOVED_TEMPORARILY=o.MOVED_PERMANENTLY=o.METHOD_NOT_ALLOWED=o.METHOD_FAILURE=o.LOCKED=o.LENGTH_REQUIRED=o.INTERNAL_SERVER_ERROR=o.INSUFFICIENT_STORAGE=o.INSUFFICIENT_SPACE_ON_RESOURCE=o.IM_A_TEAPOT=o.HTTP_VERSION_NOT_SUPPORTED=o.GONE=o.GATEWAY_TIMEOUT=o.FORBIDDEN=o.FAILED_DEPENDENCY=o.EXPECTATION_FAILED=o.CREATED=o.CONTINUE=o.CONFLICT=o.BAD_REQUEST=o.BAD_GATEWAY=o.ACCEPTED=void 0;o.ACCEPTED=202;o.BAD_GATEWAY=502;o.BAD_REQUEST=400;o.CONFLICT=409;o.CONTINUE=100;o.CREATED=201;o.EXPECTATION_FAILED=417;o.FAILED_DEPENDENCY=424;o.FORBIDDEN=403;o.GATEWAY_TIMEOUT=504;o.GONE=410;o.HTTP_VERSION_NOT_SUPPORTED=505;o.IM_A_TEAPOT=418;o.INSUFFICIENT_SPACE_ON_RESOURCE=419;o.INSUFFICIENT_STORAGE=507;o.INTERNAL_SERVER_ERROR=500;o.LENGTH_REQUIRED=411;o.LOCKED=423;o.METHOD_FAILURE=420;o.METHOD_NOT_ALLOWED=405;o.MOVED_PERMANENTLY=301;o.MOVED_TEMPORARILY=302;o.MULTI_STATUS=207;o.MULTIPLE_CHOICES=300;o.NETWORK_AUTHENTICATION_REQUIRED=511;o.NO_CONTENT=204;o.NON_AUTHORITATIVE_INFORMATION=203;o.NOT_ACCEPTABLE=406;o.NOT_FOUND=404;o.NOT_IMPLEMENTED=501;o.NOT_MODIFIED=304;o.OK=200;o.PARTIAL_CONTENT=206;o.PAYMENT_REQUIRED=402;o.PERMANENT_REDIRECT=308;o.PRECONDITION_FAILED=412;o.PRECONDITION_REQUIRED=428;o.PROCESSING=102;o.PROXY_AUTHENTICATION_REQUIRED=407;o.REQUEST_HEADER_FIELDS_TOO_LARGE=431;o.REQUEST_TIMEOUT=408;o.REQUEST_TOO_LONG=413;o.REQUEST_URI_TOO_LONG=414;o.REQUESTED_RANGE_NOT_SATISFIABLE=416;o.RESET_CONTENT=205;o.SEE_OTHER=303;o.SERVICE_UNAVAILABLE=503;o.SWITCHING_PROTOCOLS=101;o.TEMPORARY_REDIRECT=307;o.TOO_MANY_REQUESTS=429;o.UNAUTHORIZED=401;o.UNPROCESSABLE_ENTITY=422;o.UNSUPPORTED_MEDIA_TYPE=415;o.USE_PROXY=305;o.default={ACCEPTED:o.ACCEPTED,BAD_GATEWAY:o.BAD_GATEWAY,BAD_REQUEST:o.BAD_REQUEST,CONFLICT:o.CONFLICT,CONTINUE:o.CONTINUE,CREATED:o.CREATED,EXPECTATION_FAILED:o.EXPECTATION_FAILED,FORBIDDEN:o.FORBIDDEN,GATEWAY_TIMEOUT:o.GATEWAY_TIMEOUT,GONE:o.GONE,HTTP_VERSION_NOT_SUPPORTED:o.HTTP_VERSION_NOT_SUPPORTED,IM_A_TEAPOT:o.IM_A_TEAPOT,INSUFFICIENT_SPACE_ON_RESOURCE:o.INSUFFICIENT_SPACE_ON_RESOURCE,INSUFFICIENT_STORAGE:o.INSUFFICIENT_STORAGE,INTERNAL_SERVER_ERROR:o.INTERNAL_SERVER_ERROR,LENGTH_REQUIRED:o.LENGTH_REQUIRED,LOCKED:o.LOCKED,METHOD_FAILURE:o.METHOD_FAILURE,METHOD_NOT_ALLOWED:o.METHOD_NOT_ALLOWED,MOVED_PERMANENTLY:o.MOVED_PERMANENTLY,MOVED_TEMPORARILY:o.MOVED_TEMPORARILY,MULTI_STATUS:o.MULTI_STATUS,MULTIPLE_CHOICES:o.MULTIPLE_CHOICES,NETWORK_AUTHENTICATION_REQUIRED:o.NETWORK_AUTHENTICATION_REQUIRED,NO_CONTENT:o.NO_CONTENT,NON_AUTHORITATIVE_INFORMATION:o.NON_AUTHORITATIVE_INFORMATION,NOT_ACCEPTABLE:o.NOT_ACCEPTABLE,NOT_FOUND:o.NOT_FOUND,NOT_IMPLEMENTED:o.NOT_IMPLEMENTED,NOT_MODIFIED:o.NOT_MODIFIED,OK:o.OK,PARTIAL_CONTENT:o.PARTIAL_CONTENT,PAYMENT_REQUIRED:o.PAYMENT_REQUIRED,PERMANENT_REDIRECT:o.PERMANENT_REDIRECT,PRECONDITION_FAILED:o.PRECONDITION_FAILED,PRECONDITION_REQUIRED:o.PRECONDITION_REQUIRED,PROCESSING:o.PROCESSING,PROXY_AUTHENTICATION_REQUIRED:o.PROXY_AUTHENTICATION_REQUIRED,REQUEST_HEADER_FIELDS_TOO_LARGE:o.REQUEST_HEADER_FIELDS_TOO_LARGE,REQUEST_TIMEOUT:o.REQUEST_TIMEOUT,REQUEST_TOO_LONG:o.REQUEST_TOO_LONG,REQUEST_URI_TOO_LONG:o.REQUEST_URI_TOO_LONG,REQUESTED_RANGE_NOT_SATISFIABLE:o.REQUESTED_RANGE_NOT_SATISFIABLE,RESET_CONTENT:o.RESET_CONTENT,SEE_OTHER:o.SEE_OTHER,SERVICE_UNAVAILABLE:o.SERVICE_UNAVAILABLE,SWITCHING_PROTOCOLS:o.SWITCHING_PROTOCOLS,TEMPORARY_REDIRECT:o.TEMPORARY_REDIRECT,TOO_MANY_REQUESTS:o.TOO_MANY_REQUESTS,UNAUTHORIZED:o.UNAUTHORIZED,UNPROCESSABLE_ENTITY:o.UNPROCESSABLE_ENTITY,UNSUPPORTED_MEDIA_TYPE:o.UNSUPPORTED_MEDIA_TYPE,USE_PROXY:o.USE_PROXY}});var me=N(g=>{"use strict";Object.defineProperty(g,"__esModule",{value:!0});g.reasonPhraseToStatusCode=g.statusCodeToReasonPhrase=void 0;g.statusCodeToReasonPhrase={202:"Accepted",502:"Bad Gateway",400:"Bad Request",409:"Conflict",100:"Continue",201:"Created",417:"Expectation Failed",424:"Failed Dependency",403:"Forbidden",504:"Gateway Timeout",410:"Gone",505:"HTTP Version Not Supported",418:"I'm a teapot",419:"Insufficient Space on Resource",507:"Insufficient Storage",500:"Internal Server Error",411:"Length Required",423:"Locked",420:"Method Failure",405:"Method Not Allowed",301:"Moved Permanently",302:"Moved Temporarily",207:"Multi-Status",300:"Multiple Choices",511:"Network Authentication Required",204:"No Content",203:"Non Authoritative Information",406:"Not Acceptable",404:"Not Found",501:"Not Implemented",304:"Not Modified",200:"OK",206:"Partial Content",402:"Payment Required",308:"Permanent Redirect",412:"Precondition Failed",428:"Precondition Required",102:"Processing",103:"Early Hints",426:"Upgrade Required",407:"Proxy Authentication Required",431:"Request Header Fields Too Large",408:"Request Timeout",413:"Request Entity Too Large",414:"Request-URI Too Long",416:"Requested Range Not Satisfiable",205:"Reset Content",303:"See Other",503:"Service Unavailable",101:"Switching Protocols",307:"Temporary Redirect",429:"Too Many Requests",401:"Unauthorized",451:"Unavailable For Legal Reasons",422:"Unprocessable Entity",415:"Unsupported Media Type",305:"Use Proxy",421:"Misdirected Request"};g.reasonPhraseToStatusCode={Accepted:202,"Bad Gateway":502,"Bad Request":400,Conflict:409,Continue:100,Created:201,"Expectation Failed":417,"Failed Dependency":424,Forbidden:403,"Gateway Timeout":504,Gone:410,"HTTP Version Not Supported":505,"I'm a teapot":418,"Insufficient Space on Resource":419,"Insufficient Storage":507,"Internal Server Error":500,"Length Required":411,Locked:423,"Method Failure":420,"Method Not Allowed":405,"Moved Permanently":301,"Moved Temporarily":302,"Multi-Status":207,"Multiple Choices":300,"Network Authentication Required":511,"No Content":204,"Non Authoritative Information":203,"Not Acceptable":406,"Not Found":404,"Not Implemented":501,"Not Modified":304,OK:200,"Partial Content":206,"Payment Required":402,"Permanent Redirect":308,"Precondition Failed":412,"Precondition Required":428,Processing:102,"Early Hints":103,"Upgrade Required":426,"Proxy Authentication Required":407,"Request Header Fields Too Large":431,"Request Timeout":408,"Request Entity Too Large":413,"Request-URI Too Long":414,"Requested Range Not Satisfiable":416,"Reset Content":205,"See Other":303,"Service Unavailable":503,"Switching Protocols":101,"Temporary Redirect":307,"Too Many Requests":429,Unauthorized:401,"Unavailable For Legal Reasons":451,"Unprocessable Entity":422,"Unsupported Media Type":415,"Use Proxy":305,"Misdirected Request":421}});var K=N(p=>{"use strict";Object.defineProperty(p,"__esModule",{value:!0});p.getStatusText=p.getStatusCode=p.getReasonPhrase=void 0;var de=me();function Te(e){var r=de.statusCodeToReasonPhrase[e.toString()];if(!r)throw new Error("Status code does not exist: "+e);return r}p.getReasonPhrase=Te;function nt(e){var r=de.reasonPhraseToStatusCode[e];if(!r)throw new Error("Reason phrase does not exist: "+e);return r}p.getStatusCode=nt;p.getStatusText=Te});var pe=N(y=>{"use strict";Object.defineProperty(y,"__esModule",{value:!0});y.StatusCodes=void 0;var it;(function(e){e[e.CONTINUE=100]="CONTINUE",e[e.SWITCHING_PROTOCOLS=101]="SWITCHING_PROTOCOLS",e[e.PROCESSING=102]="PROCESSING",e[e.EARLY_HINTS=103]="EARLY_HINTS",e[e.OK=200]="OK",e[e.CREATED=201]="CREATED",e[e.ACCEPTED=202]="ACCEPTED",e[e.NON_AUTHORITATIVE_INFORMATION=203]="NON_AUTHORITATIVE_INFORMATION",e[e.NO_CONTENT=204]="NO_CONTENT",e[e.RESET_CONTENT=205]="RESET_CONTENT",e[e.PARTIAL_CONTENT=206]="PARTIAL_CONTENT",e[e.MULTI_STATUS=207]="MULTI_STATUS",e[e.MULTIPLE_CHOICES=300]="MULTIPLE_CHOICES",e[e.MOVED_PERMANENTLY=301]="MOVED_PERMANENTLY",e[e.MOVED_TEMPORARILY=302]="MOVED_TEMPORARILY",e[e.SEE_OTHER=303]="SEE_OTHER",e[e.NOT_MODIFIED=304]="NOT_MODIFIED",e[e.USE_PROXY=305]="USE_PROXY",e[e.TEMPORARY_REDIRECT=307]="TEMPORARY_REDIRECT",e[e.PERMANENT_REDIRECT=308]="PERMANENT_REDIRECT",e[e.BAD_REQUEST=400]="BAD_REQUEST",e[e.UNAUTHORIZED=401]="UNAUTHORIZED",e[e.PAYMENT_REQUIRED=402]="PAYMENT_REQUIRED",e[e.FORBIDDEN=403]="FORBIDDEN",e[e.NOT_FOUND=404]="NOT_FOUND",e[e.METHOD_NOT_ALLOWED=405]="METHOD_NOT_ALLOWED",e[e.NOT_ACCEPTABLE=406]="NOT_ACCEPTABLE",e[e.PROXY_AUTHENTICATION_REQUIRED=407]="PROXY_AUTHENTICATION_REQUIRED",e[e.REQUEST_TIMEOUT=408]="REQUEST_TIMEOUT",e[e.CONFLICT=409]="CONFLICT",e[e.GONE=410]="GONE",e[e.LENGTH_REQUIRED=411]="LENGTH_REQUIRED",e[e.PRECONDITION_FAILED=412]="PRECONDITION_FAILED",e[e.REQUEST_TOO_LONG=413]="REQUEST_TOO_LONG",e[e.REQUEST_URI_TOO_LONG=414]="REQUEST_URI_TOO_LONG",e[e.UNSUPPORTED_MEDIA_TYPE=415]="UNSUPPORTED_MEDIA_TYPE",e[e.REQUESTED_RANGE_NOT_SATISFIABLE=416]="REQUESTED_RANGE_NOT_SATISFIABLE",e[e.EXPECTATION_FAILED=417]="EXPECTATION_FAILED",e[e.IM_A_TEAPOT=418]="IM_A_TEAPOT",e[e.INSUFFICIENT_SPACE_ON_RESOURCE=419]="INSUFFICIENT_SPACE_ON_RESOURCE",e[e.METHOD_FAILURE=420]="METHOD_FAILURE",e[e.MISDIRECTED_REQUEST=421]="MISDIRECTED_REQUEST",e[e.UNPROCESSABLE_ENTITY=422]="UNPROCESSABLE_ENTITY",e[e.LOCKED=423]="LOCKED",e[e.FAILED_DEPENDENCY=424]="FAILED_DEPENDENCY",e[e.UPGRADE_REQUIRED=426]="UPGRADE_REQUIRED",e[e.PRECONDITION_REQUIRED=428]="PRECONDITION_REQUIRED",e[e.TOO_MANY_REQUESTS=429]="TOO_MANY_REQUESTS",e[e.REQUEST_HEADER_FIELDS_TOO_LARGE=431]="REQUEST_HEADER_FIELDS_TOO_LARGE",e[e.UNAVAILABLE_FOR_LEGAL_REASONS=451]="UNAVAILABLE_FOR_LEGAL_REASONS",e[e.INTERNAL_SERVER_ERROR=500]="INTERNAL_SERVER_ERROR",e[e.NOT_IMPLEMENTED=501]="NOT_IMPLEMENTED",e[e.BAD_GATEWAY=502]="BAD_GATEWAY",e[e.SERVICE_UNAVAILABLE=503]="SERVICE_UNAVAILABLE",e[e.GATEWAY_TIMEOUT=504]="GATEWAY_TIMEOUT",e[e.HTTP_VERSION_NOT_SUPPORTED=505]="HTTP_VERSION_NOT_SUPPORTED",e[e.INSUFFICIENT_STORAGE=507]="INSUFFICIENT_STORAGE",e[e.NETWORK_AUTHENTICATION_REQUIRED=511]="NETWORK_AUTHENTICATION_REQUIRED"})(it=y.StatusCodes||(y.StatusCodes={}))});var fe=N(U=>{"use strict";Object.defineProperty(U,"__esModule",{value:!0});U.ReasonPhrases=void 0;var at;(function(e){e.ACCEPTED="Accepted",e.BAD_GATEWAY="Bad Gateway",e.BAD_REQUEST="Bad Request",e.CONFLICT="Conflict",e.CONTINUE="Continue",e.CREATED="Created",e.EXPECTATION_FAILED="Expectation Failed",e.FAILED_DEPENDENCY="Failed Dependency",e.FORBIDDEN="Forbidden",e.GATEWAY_TIMEOUT="Gateway Timeout",e.GONE="Gone",e.HTTP_VERSION_NOT_SUPPORTED="HTTP Version Not Supported",e.IM_A_TEAPOT="I'm a teapot",e.INSUFFICIENT_SPACE_ON_RESOURCE="Insufficient Space on Resource",e.INSUFFICIENT_STORAGE="Insufficient Storage",e.INTERNAL_SERVER_ERROR="Internal Server Error",e.LENGTH_REQUIRED="Length Required",e.LOCKED="Locked",e.METHOD_FAILURE="Method Failure",e.METHOD_NOT_ALLOWED="Method Not Allowed",e.MOVED_PERMANENTLY="Moved Permanently",e.MOVED_TEMPORARILY="Moved Temporarily",e.MULTI_STATUS="Multi-Status",e.MULTIPLE_CHOICES="Multiple Choices",e.NETWORK_AUTHENTICATION_REQUIRED="Network Authentication Required",e.NO_CONTENT="No Content",e.NON_AUTHORITATIVE_INFORMATION="Non Authoritative Information",e.NOT_ACCEPTABLE="Not Acceptable",e.NOT_FOUND="Not Found",e.NOT_IMPLEMENTED="Not Implemented",e.NOT_MODIFIED="Not Modified",e.OK="OK",e.PARTIAL_CONTENT="Partial Content",e.PAYMENT_REQUIRED="Payment Required",e.PERMANENT_REDIRECT="Permanent Redirect",e.PRECONDITION_FAILED="Precondition Failed",e.PRECONDITION_REQUIRED="Precondition Required",e.PROCESSING="Processing",e.EARLY_HINTS="Early Hints",e.UPGRADE_REQUIRED="Upgrade Required",e.PROXY_AUTHENTICATION_REQUIRED="Proxy Authentication Required",e.REQUEST_HEADER_FIELDS_TOO_LARGE="Request Header Fields Too Large",e.REQUEST_TIMEOUT="Request Timeout",e.REQUEST_TOO_LONG="Request Entity Too Large",e.REQUEST_URI_TOO_LONG="Request-URI Too Long",e.REQUESTED_RANGE_NOT_SATISFIABLE="Requested Range Not Satisfiable",e.RESET_CONTENT="Reset Content",e.SEE_OTHER="See Other",e.SERVICE_UNAVAILABLE="Service Unavailable",e.SWITCHING_PROTOCOLS="Switching Protocols",e.TEMPORARY_REDIRECT="Temporary Redirect",e.TOO_MANY_REQUESTS="Too Many Requests",e.UNAUTHORIZED="Unauthorized",e.UNAVAILABLE_FOR_LEGAL_REASONS="Unavailable For Legal Reasons",e.UNPROCESSABLE_ENTITY="Unprocessable Entity",e.UNSUPPORTED_MEDIA_TYPE="Unsupported Media Type",e.USE_PROXY="Use Proxy",e.MISDIRECTED_REQUEST="Misdirected Request"})(at=U.ReasonPhrases||(U.ReasonPhrases={}))});var Oe=N(l=>{"use strict";var v=l&&l.__assign||function(){return v=Object.assign||function(e){for(var r,t=1,n=arguments.length;t<n;t++){r=arguments[t];for(var i in r)Object.prototype.hasOwnProperty.call(r,i)&&(e[i]=r[i])}return e},v.apply(this,arguments)},ut=l&&l.__createBinding||(Object.create?(function(e,r,t,n){n===void 0&&(n=t),Object.defineProperty(e,n,{enumerable:!0,get:function(){return r[t]}})}):(function(e,r,t,n){n===void 0&&(n=t),e[n]=r[t]})),st=l&&l.__exportStar||function(e,r){for(var t in e)t!=="default"&&!r.hasOwnProperty(t)&&ut(r,e,t)},ct=l&&l.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(l,"__esModule",{value:!0});var Et=ct($()),_e=K(),z=K();Object.defineProperty(l,"getStatusCode",{enumerable:!0,get:function(){return z.getStatusCode}});Object.defineProperty(l,"getReasonPhrase",{enumerable:!0,get:function(){return z.getReasonPhrase}});Object.defineProperty(l,"getStatusText",{enumerable:!0,get:function(){return z.getStatusText}});var lt=pe();Object.defineProperty(l,"StatusCodes",{enumerable:!0,get:function(){return lt.StatusCodes}});var Rt=fe();Object.defineProperty(l,"ReasonPhrases",{enumerable:!0,get:function(){return Rt.ReasonPhrases}});st($(),l);l.default=v(v({},Et.default),{getStatusCode:_e.getStatusCode,getStatusText:_e.getStatusText})});var gt={};je(gt,{ApiGatewayExecutionRouters:()=>xe,ApiGatewayStages:()=>Pe,AwsRegionSchema:()=>Ot,BrowserPipeline:()=>F,CloudFrontDistributions:()=>Le,DEFAULT_CLI_CONFIG:()=>It,DeployStacks:()=>Me,DynamoDbTables:()=>Ce,EnginesBrowserFramework:()=>De,ErrorBoundary:()=>k,ErrorBoundaryNotFound:()=>et,FeaturesConfigSchema:()=>he,IamExecutionRoles:()=>we,LambdaFunctions:()=>ve,PathsConfigSchema:()=>Ue,RuntimeAppServer:()=>le,RuntimeConfigSchema:()=>Nt,RuntimeHeadManager:()=>tt,RuntimeRouter:()=>I,RuntimeRouterProvider:()=>Ze,S3Buckets:()=>be,StageConfigSchema:()=>ye,createRouteLoader:()=>V,createSeoRetriever:()=>Q,executeRuntimeAsync:()=>oe,fetchSeoMetadata:()=>re,getDefaultSeoMeta:()=>W,injectFlow:()=>se,intersection:()=>j,isBrowser:()=>X,isLambdaRuntime:()=>w,isValidServiceName:()=>Se,mergeLoaderResults:()=>ne,routePath:()=>T,routerContext:()=>Z,runtime:()=>pt,runtimeRouter:()=>Je,runtimeThreads:()=>ge,useRuntimeData:()=>qe,useRuntimeSeoMeta:()=>$e});module.exports=ke(gt);var u=f(require("react")),ce=require("react");var G=require("react-router");function qe(){let e=(0,G.useLoaderData)();if(e===void 0)throw new Error("[Runtime] useRuntimeData must be called within a route component with a loader. Ensure the route has a loader function or runtimeAsync retrievers defined.");if(typeof e!="object"||e===null)throw new Error('[Runtime] useRuntimeData received invalid loader data. Expected an object with "internal" and "business" properties.');if(!("business"in e))throw new Error('[Runtime] useRuntimeData received loader data without "business" property. This may indicate the route is not using a Runtime-generated loader.');return e.business}function $e(){let e=(0,G.useLoaderData)();if(e&&!(typeof e!="object"||e===null)&&"internal"in e)return e.internal?.seoMeta}function Ke(e){let r=process.env.PURE_ENV_API_BASE_URL;if(!r)throw new Error("[Runtime] PURE_ENV_API_BASE_URL environment variable is not configured. Please set this variable to your API Gateway base URL.");return`${r.replace(/\/+$/,"")}/seo-meta?route=${encodeURIComponent(e)}`}async function te(e){try{let r=Ke(e),t=await fetch(r);if(!t.ok)return console.warn(`[Runtime] SEO API returned status ${t.status} for route "${e}"`),null;let n=await t.json();return ze(n)}catch(r){return r instanceof Error&&r.message.includes("PURE_ENV_API_BASE_URL")?console.error(r.message):console.warn(`[Runtime] Failed to fetch SEO metadata from API for route "${e}":`,r),null}}function ze(e){return{title:e.title,description:e.description,keywords:e.keywords,ogTitle:e.ogTitle,ogDescription:e.ogDescription,ogImage:e.ogImage,ogUrl:e.canonicalUrl,ogType:"website",twitterCard:"summary",twitterTitle:e.twitterTitle,twitterDescription:e.twitterDescription,twitterImage:e.twitterImage,canonicalUrl:e.canonicalUrl,robots:e.robots}}function Q(e){return async r=>{try{return{seoMeta:await re(e,r)||W()}}catch(t){return console.warn(`[Runtime] SEO retriever failed for route "${e}":`,t),{seoMeta:W()}}}}async function re(e,r){if(typeof window>"u")return null;try{let t=e;return r.params&&Object.entries(r.params).forEach(([n,i])=>{t=t.replace(`:${n}`,String(i))}),await te(t)}catch(t){return console.warn(`[Runtime] Failed to fetch SEO metadata for route "${e}":`,t),null}}function W(){return{title:"Runtime Web Application",description:"A Runtime Web serverless application",robots:"index, follow",keywords:["aws","serverless","react","serverless rendering"],ogTitle:"Runtime Web Application",ogDescription:"A Runtime Web serverless application",ogImage:"/og-image.png",ogUrl:"/",ogType:"website",twitterCard:"summary_large_image",twitterTitle:"Runtime Web Application",twitterDescription:"A Runtime Web serverless application",twitterImage:"/twitter-card.png",canonicalUrl:"/"}}var Y="internal";function V(e,r){return async t=>{let{params:n,request:i}=t,c=new URL(i.url).searchParams,R={params:n,request:i,searchParams:c},m=[{retriever:Q(e),isInternal:!0,name:"Internal SEO retriever"}],d=r.map((He,Be)=>({retriever:He,isInternal:!1,name:`User retriever ${Be+1}`})),E=[...m,...d],Fe=await oe(E,R,e);return ne(Fe,E,e)}}async function oe(e,r,t){if(e.length===0)return[];let n=e.map(({retriever:i})=>i(r));return Promise.allSettled(n)}function ne(e,r,t){let n={internal:{},business:{}};return e.forEach((i,a)=>{let{isInternal:c,name:R}=r[a];if(i.status==="fulfilled"){let m=i.value;if(c)Object.assign(n.internal,m);else if(Y in m){console.warn(`[Runtime] ${R} for route "${t}" returned reserved key "${Y}", ignoring it`);let{[Y]:d,...E}=m;Object.assign(n.business,E)}else Object.assign(n.business,m)}else Xe(i.reason,R,t,c)}),n}function Xe(e,r,t,n){let i;try{i=e instanceof Error?e:new Error(String(e))}catch{try{i=new Error(JSON.stringify(e))}catch{i=new Error("[Unable to serialize error reason]")}}let a=i.message,c=i.stack,R="[Runtime Loader Error]",m={retriever:r,route:t,type:n?"internal":"user",timestamp:new Date().toISOString()};console.warn(`${R} ${r} failed for route "${t}"`,`
1
+ "use strict";var Ge=Object.create;var h=Object.defineProperty;var We=Object.getOwnPropertyDescriptor;var Qe=Object.getOwnPropertyNames;var Ye=Object.getPrototypeOf,Ve=Object.prototype.hasOwnProperty;var N=(e,r)=>()=>(r||e((r={exports:{}}).exports,r),r.exports),je=(e,r)=>{for(var t in r)h(e,t,{get:r[t],enumerable:!0})},ee=(e,r,t,n)=>{if(r&&typeof r=="object"||typeof r=="function")for(let i of Qe(r))!Ve.call(e,i)&&i!==t&&h(e,i,{get:()=>r[i],enumerable:!(n=We(r,i))||n.enumerable});return e};var f=(e,r,t)=>(t=e!=null?Ge(Ye(e)):{},ee(r||!e||!e.__esModule?h(t,"default",{value:e,enumerable:!0}):t,e)),ke=e=>ee(h({},"__esModule",{value:!0}),e);var $=N(o=>{"use strict";Object.defineProperty(o,"__esModule",{value:!0});o.USE_PROXY=o.UNSUPPORTED_MEDIA_TYPE=o.UNPROCESSABLE_ENTITY=o.UNAUTHORIZED=o.TOO_MANY_REQUESTS=o.TEMPORARY_REDIRECT=o.SWITCHING_PROTOCOLS=o.SERVICE_UNAVAILABLE=o.SEE_OTHER=o.RESET_CONTENT=o.REQUESTED_RANGE_NOT_SATISFIABLE=o.REQUEST_URI_TOO_LONG=o.REQUEST_TOO_LONG=o.REQUEST_TIMEOUT=o.REQUEST_HEADER_FIELDS_TOO_LARGE=o.PROXY_AUTHENTICATION_REQUIRED=o.PROCESSING=o.PRECONDITION_REQUIRED=o.PRECONDITION_FAILED=o.PERMANENT_REDIRECT=o.PAYMENT_REQUIRED=o.PARTIAL_CONTENT=o.OK=o.NOT_MODIFIED=o.NOT_IMPLEMENTED=o.NOT_FOUND=o.NOT_ACCEPTABLE=o.NON_AUTHORITATIVE_INFORMATION=o.NO_CONTENT=o.NETWORK_AUTHENTICATION_REQUIRED=o.MULTIPLE_CHOICES=o.MULTI_STATUS=o.MOVED_TEMPORARILY=o.MOVED_PERMANENTLY=o.METHOD_NOT_ALLOWED=o.METHOD_FAILURE=o.LOCKED=o.LENGTH_REQUIRED=o.INTERNAL_SERVER_ERROR=o.INSUFFICIENT_STORAGE=o.INSUFFICIENT_SPACE_ON_RESOURCE=o.IM_A_TEAPOT=o.HTTP_VERSION_NOT_SUPPORTED=o.GONE=o.GATEWAY_TIMEOUT=o.FORBIDDEN=o.FAILED_DEPENDENCY=o.EXPECTATION_FAILED=o.CREATED=o.CONTINUE=o.CONFLICT=o.BAD_REQUEST=o.BAD_GATEWAY=o.ACCEPTED=void 0;o.ACCEPTED=202;o.BAD_GATEWAY=502;o.BAD_REQUEST=400;o.CONFLICT=409;o.CONTINUE=100;o.CREATED=201;o.EXPECTATION_FAILED=417;o.FAILED_DEPENDENCY=424;o.FORBIDDEN=403;o.GATEWAY_TIMEOUT=504;o.GONE=410;o.HTTP_VERSION_NOT_SUPPORTED=505;o.IM_A_TEAPOT=418;o.INSUFFICIENT_SPACE_ON_RESOURCE=419;o.INSUFFICIENT_STORAGE=507;o.INTERNAL_SERVER_ERROR=500;o.LENGTH_REQUIRED=411;o.LOCKED=423;o.METHOD_FAILURE=420;o.METHOD_NOT_ALLOWED=405;o.MOVED_PERMANENTLY=301;o.MOVED_TEMPORARILY=302;o.MULTI_STATUS=207;o.MULTIPLE_CHOICES=300;o.NETWORK_AUTHENTICATION_REQUIRED=511;o.NO_CONTENT=204;o.NON_AUTHORITATIVE_INFORMATION=203;o.NOT_ACCEPTABLE=406;o.NOT_FOUND=404;o.NOT_IMPLEMENTED=501;o.NOT_MODIFIED=304;o.OK=200;o.PARTIAL_CONTENT=206;o.PAYMENT_REQUIRED=402;o.PERMANENT_REDIRECT=308;o.PRECONDITION_FAILED=412;o.PRECONDITION_REQUIRED=428;o.PROCESSING=102;o.PROXY_AUTHENTICATION_REQUIRED=407;o.REQUEST_HEADER_FIELDS_TOO_LARGE=431;o.REQUEST_TIMEOUT=408;o.REQUEST_TOO_LONG=413;o.REQUEST_URI_TOO_LONG=414;o.REQUESTED_RANGE_NOT_SATISFIABLE=416;o.RESET_CONTENT=205;o.SEE_OTHER=303;o.SERVICE_UNAVAILABLE=503;o.SWITCHING_PROTOCOLS=101;o.TEMPORARY_REDIRECT=307;o.TOO_MANY_REQUESTS=429;o.UNAUTHORIZED=401;o.UNPROCESSABLE_ENTITY=422;o.UNSUPPORTED_MEDIA_TYPE=415;o.USE_PROXY=305;o.default={ACCEPTED:o.ACCEPTED,BAD_GATEWAY:o.BAD_GATEWAY,BAD_REQUEST:o.BAD_REQUEST,CONFLICT:o.CONFLICT,CONTINUE:o.CONTINUE,CREATED:o.CREATED,EXPECTATION_FAILED:o.EXPECTATION_FAILED,FORBIDDEN:o.FORBIDDEN,GATEWAY_TIMEOUT:o.GATEWAY_TIMEOUT,GONE:o.GONE,HTTP_VERSION_NOT_SUPPORTED:o.HTTP_VERSION_NOT_SUPPORTED,IM_A_TEAPOT:o.IM_A_TEAPOT,INSUFFICIENT_SPACE_ON_RESOURCE:o.INSUFFICIENT_SPACE_ON_RESOURCE,INSUFFICIENT_STORAGE:o.INSUFFICIENT_STORAGE,INTERNAL_SERVER_ERROR:o.INTERNAL_SERVER_ERROR,LENGTH_REQUIRED:o.LENGTH_REQUIRED,LOCKED:o.LOCKED,METHOD_FAILURE:o.METHOD_FAILURE,METHOD_NOT_ALLOWED:o.METHOD_NOT_ALLOWED,MOVED_PERMANENTLY:o.MOVED_PERMANENTLY,MOVED_TEMPORARILY:o.MOVED_TEMPORARILY,MULTI_STATUS:o.MULTI_STATUS,MULTIPLE_CHOICES:o.MULTIPLE_CHOICES,NETWORK_AUTHENTICATION_REQUIRED:o.NETWORK_AUTHENTICATION_REQUIRED,NO_CONTENT:o.NO_CONTENT,NON_AUTHORITATIVE_INFORMATION:o.NON_AUTHORITATIVE_INFORMATION,NOT_ACCEPTABLE:o.NOT_ACCEPTABLE,NOT_FOUND:o.NOT_FOUND,NOT_IMPLEMENTED:o.NOT_IMPLEMENTED,NOT_MODIFIED:o.NOT_MODIFIED,OK:o.OK,PARTIAL_CONTENT:o.PARTIAL_CONTENT,PAYMENT_REQUIRED:o.PAYMENT_REQUIRED,PERMANENT_REDIRECT:o.PERMANENT_REDIRECT,PRECONDITION_FAILED:o.PRECONDITION_FAILED,PRECONDITION_REQUIRED:o.PRECONDITION_REQUIRED,PROCESSING:o.PROCESSING,PROXY_AUTHENTICATION_REQUIRED:o.PROXY_AUTHENTICATION_REQUIRED,REQUEST_HEADER_FIELDS_TOO_LARGE:o.REQUEST_HEADER_FIELDS_TOO_LARGE,REQUEST_TIMEOUT:o.REQUEST_TIMEOUT,REQUEST_TOO_LONG:o.REQUEST_TOO_LONG,REQUEST_URI_TOO_LONG:o.REQUEST_URI_TOO_LONG,REQUESTED_RANGE_NOT_SATISFIABLE:o.REQUESTED_RANGE_NOT_SATISFIABLE,RESET_CONTENT:o.RESET_CONTENT,SEE_OTHER:o.SEE_OTHER,SERVICE_UNAVAILABLE:o.SERVICE_UNAVAILABLE,SWITCHING_PROTOCOLS:o.SWITCHING_PROTOCOLS,TEMPORARY_REDIRECT:o.TEMPORARY_REDIRECT,TOO_MANY_REQUESTS:o.TOO_MANY_REQUESTS,UNAUTHORIZED:o.UNAUTHORIZED,UNPROCESSABLE_ENTITY:o.UNPROCESSABLE_ENTITY,UNSUPPORTED_MEDIA_TYPE:o.UNSUPPORTED_MEDIA_TYPE,USE_PROXY:o.USE_PROXY}});var me=N(g=>{"use strict";Object.defineProperty(g,"__esModule",{value:!0});g.reasonPhraseToStatusCode=g.statusCodeToReasonPhrase=void 0;g.statusCodeToReasonPhrase={202:"Accepted",502:"Bad Gateway",400:"Bad Request",409:"Conflict",100:"Continue",201:"Created",417:"Expectation Failed",424:"Failed Dependency",403:"Forbidden",504:"Gateway Timeout",410:"Gone",505:"HTTP Version Not Supported",418:"I'm a teapot",419:"Insufficient Space on Resource",507:"Insufficient Storage",500:"Internal Server Error",411:"Length Required",423:"Locked",420:"Method Failure",405:"Method Not Allowed",301:"Moved Permanently",302:"Moved Temporarily",207:"Multi-Status",300:"Multiple Choices",511:"Network Authentication Required",204:"No Content",203:"Non Authoritative Information",406:"Not Acceptable",404:"Not Found",501:"Not Implemented",304:"Not Modified",200:"OK",206:"Partial Content",402:"Payment Required",308:"Permanent Redirect",412:"Precondition Failed",428:"Precondition Required",102:"Processing",103:"Early Hints",426:"Upgrade Required",407:"Proxy Authentication Required",431:"Request Header Fields Too Large",408:"Request Timeout",413:"Request Entity Too Large",414:"Request-URI Too Long",416:"Requested Range Not Satisfiable",205:"Reset Content",303:"See Other",503:"Service Unavailable",101:"Switching Protocols",307:"Temporary Redirect",429:"Too Many Requests",401:"Unauthorized",451:"Unavailable For Legal Reasons",422:"Unprocessable Entity",415:"Unsupported Media Type",305:"Use Proxy",421:"Misdirected Request"};g.reasonPhraseToStatusCode={Accepted:202,"Bad Gateway":502,"Bad Request":400,Conflict:409,Continue:100,Created:201,"Expectation Failed":417,"Failed Dependency":424,Forbidden:403,"Gateway Timeout":504,Gone:410,"HTTP Version Not Supported":505,"I'm a teapot":418,"Insufficient Space on Resource":419,"Insufficient Storage":507,"Internal Server Error":500,"Length Required":411,Locked:423,"Method Failure":420,"Method Not Allowed":405,"Moved Permanently":301,"Moved Temporarily":302,"Multi-Status":207,"Multiple Choices":300,"Network Authentication Required":511,"No Content":204,"Non Authoritative Information":203,"Not Acceptable":406,"Not Found":404,"Not Implemented":501,"Not Modified":304,OK:200,"Partial Content":206,"Payment Required":402,"Permanent Redirect":308,"Precondition Failed":412,"Precondition Required":428,Processing:102,"Early Hints":103,"Upgrade Required":426,"Proxy Authentication Required":407,"Request Header Fields Too Large":431,"Request Timeout":408,"Request Entity Too Large":413,"Request-URI Too Long":414,"Requested Range Not Satisfiable":416,"Reset Content":205,"See Other":303,"Service Unavailable":503,"Switching Protocols":101,"Temporary Redirect":307,"Too Many Requests":429,Unauthorized:401,"Unavailable For Legal Reasons":451,"Unprocessable Entity":422,"Unsupported Media Type":415,"Use Proxy":305,"Misdirected Request":421}});var K=N(p=>{"use strict";Object.defineProperty(p,"__esModule",{value:!0});p.getStatusText=p.getStatusCode=p.getReasonPhrase=void 0;var de=me();function Te(e){var r=de.statusCodeToReasonPhrase[e.toString()];if(!r)throw new Error("Status code does not exist: "+e);return r}p.getReasonPhrase=Te;function nt(e){var r=de.reasonPhraseToStatusCode[e];if(!r)throw new Error("Reason phrase does not exist: "+e);return r}p.getStatusCode=nt;p.getStatusText=Te});var pe=N(y=>{"use strict";Object.defineProperty(y,"__esModule",{value:!0});y.StatusCodes=void 0;var it;(function(e){e[e.CONTINUE=100]="CONTINUE",e[e.SWITCHING_PROTOCOLS=101]="SWITCHING_PROTOCOLS",e[e.PROCESSING=102]="PROCESSING",e[e.EARLY_HINTS=103]="EARLY_HINTS",e[e.OK=200]="OK",e[e.CREATED=201]="CREATED",e[e.ACCEPTED=202]="ACCEPTED",e[e.NON_AUTHORITATIVE_INFORMATION=203]="NON_AUTHORITATIVE_INFORMATION",e[e.NO_CONTENT=204]="NO_CONTENT",e[e.RESET_CONTENT=205]="RESET_CONTENT",e[e.PARTIAL_CONTENT=206]="PARTIAL_CONTENT",e[e.MULTI_STATUS=207]="MULTI_STATUS",e[e.MULTIPLE_CHOICES=300]="MULTIPLE_CHOICES",e[e.MOVED_PERMANENTLY=301]="MOVED_PERMANENTLY",e[e.MOVED_TEMPORARILY=302]="MOVED_TEMPORARILY",e[e.SEE_OTHER=303]="SEE_OTHER",e[e.NOT_MODIFIED=304]="NOT_MODIFIED",e[e.USE_PROXY=305]="USE_PROXY",e[e.TEMPORARY_REDIRECT=307]="TEMPORARY_REDIRECT",e[e.PERMANENT_REDIRECT=308]="PERMANENT_REDIRECT",e[e.BAD_REQUEST=400]="BAD_REQUEST",e[e.UNAUTHORIZED=401]="UNAUTHORIZED",e[e.PAYMENT_REQUIRED=402]="PAYMENT_REQUIRED",e[e.FORBIDDEN=403]="FORBIDDEN",e[e.NOT_FOUND=404]="NOT_FOUND",e[e.METHOD_NOT_ALLOWED=405]="METHOD_NOT_ALLOWED",e[e.NOT_ACCEPTABLE=406]="NOT_ACCEPTABLE",e[e.PROXY_AUTHENTICATION_REQUIRED=407]="PROXY_AUTHENTICATION_REQUIRED",e[e.REQUEST_TIMEOUT=408]="REQUEST_TIMEOUT",e[e.CONFLICT=409]="CONFLICT",e[e.GONE=410]="GONE",e[e.LENGTH_REQUIRED=411]="LENGTH_REQUIRED",e[e.PRECONDITION_FAILED=412]="PRECONDITION_FAILED",e[e.REQUEST_TOO_LONG=413]="REQUEST_TOO_LONG",e[e.REQUEST_URI_TOO_LONG=414]="REQUEST_URI_TOO_LONG",e[e.UNSUPPORTED_MEDIA_TYPE=415]="UNSUPPORTED_MEDIA_TYPE",e[e.REQUESTED_RANGE_NOT_SATISFIABLE=416]="REQUESTED_RANGE_NOT_SATISFIABLE",e[e.EXPECTATION_FAILED=417]="EXPECTATION_FAILED",e[e.IM_A_TEAPOT=418]="IM_A_TEAPOT",e[e.INSUFFICIENT_SPACE_ON_RESOURCE=419]="INSUFFICIENT_SPACE_ON_RESOURCE",e[e.METHOD_FAILURE=420]="METHOD_FAILURE",e[e.MISDIRECTED_REQUEST=421]="MISDIRECTED_REQUEST",e[e.UNPROCESSABLE_ENTITY=422]="UNPROCESSABLE_ENTITY",e[e.LOCKED=423]="LOCKED",e[e.FAILED_DEPENDENCY=424]="FAILED_DEPENDENCY",e[e.UPGRADE_REQUIRED=426]="UPGRADE_REQUIRED",e[e.PRECONDITION_REQUIRED=428]="PRECONDITION_REQUIRED",e[e.TOO_MANY_REQUESTS=429]="TOO_MANY_REQUESTS",e[e.REQUEST_HEADER_FIELDS_TOO_LARGE=431]="REQUEST_HEADER_FIELDS_TOO_LARGE",e[e.UNAVAILABLE_FOR_LEGAL_REASONS=451]="UNAVAILABLE_FOR_LEGAL_REASONS",e[e.INTERNAL_SERVER_ERROR=500]="INTERNAL_SERVER_ERROR",e[e.NOT_IMPLEMENTED=501]="NOT_IMPLEMENTED",e[e.BAD_GATEWAY=502]="BAD_GATEWAY",e[e.SERVICE_UNAVAILABLE=503]="SERVICE_UNAVAILABLE",e[e.GATEWAY_TIMEOUT=504]="GATEWAY_TIMEOUT",e[e.HTTP_VERSION_NOT_SUPPORTED=505]="HTTP_VERSION_NOT_SUPPORTED",e[e.INSUFFICIENT_STORAGE=507]="INSUFFICIENT_STORAGE",e[e.NETWORK_AUTHENTICATION_REQUIRED=511]="NETWORK_AUTHENTICATION_REQUIRED"})(it=y.StatusCodes||(y.StatusCodes={}))});var fe=N(U=>{"use strict";Object.defineProperty(U,"__esModule",{value:!0});U.ReasonPhrases=void 0;var at;(function(e){e.ACCEPTED="Accepted",e.BAD_GATEWAY="Bad Gateway",e.BAD_REQUEST="Bad Request",e.CONFLICT="Conflict",e.CONTINUE="Continue",e.CREATED="Created",e.EXPECTATION_FAILED="Expectation Failed",e.FAILED_DEPENDENCY="Failed Dependency",e.FORBIDDEN="Forbidden",e.GATEWAY_TIMEOUT="Gateway Timeout",e.GONE="Gone",e.HTTP_VERSION_NOT_SUPPORTED="HTTP Version Not Supported",e.IM_A_TEAPOT="I'm a teapot",e.INSUFFICIENT_SPACE_ON_RESOURCE="Insufficient Space on Resource",e.INSUFFICIENT_STORAGE="Insufficient Storage",e.INTERNAL_SERVER_ERROR="Internal Server Error",e.LENGTH_REQUIRED="Length Required",e.LOCKED="Locked",e.METHOD_FAILURE="Method Failure",e.METHOD_NOT_ALLOWED="Method Not Allowed",e.MOVED_PERMANENTLY="Moved Permanently",e.MOVED_TEMPORARILY="Moved Temporarily",e.MULTI_STATUS="Multi-Status",e.MULTIPLE_CHOICES="Multiple Choices",e.NETWORK_AUTHENTICATION_REQUIRED="Network Authentication Required",e.NO_CONTENT="No Content",e.NON_AUTHORITATIVE_INFORMATION="Non Authoritative Information",e.NOT_ACCEPTABLE="Not Acceptable",e.NOT_FOUND="Not Found",e.NOT_IMPLEMENTED="Not Implemented",e.NOT_MODIFIED="Not Modified",e.OK="OK",e.PARTIAL_CONTENT="Partial Content",e.PAYMENT_REQUIRED="Payment Required",e.PERMANENT_REDIRECT="Permanent Redirect",e.PRECONDITION_FAILED="Precondition Failed",e.PRECONDITION_REQUIRED="Precondition Required",e.PROCESSING="Processing",e.EARLY_HINTS="Early Hints",e.UPGRADE_REQUIRED="Upgrade Required",e.PROXY_AUTHENTICATION_REQUIRED="Proxy Authentication Required",e.REQUEST_HEADER_FIELDS_TOO_LARGE="Request Header Fields Too Large",e.REQUEST_TIMEOUT="Request Timeout",e.REQUEST_TOO_LONG="Request Entity Too Large",e.REQUEST_URI_TOO_LONG="Request-URI Too Long",e.REQUESTED_RANGE_NOT_SATISFIABLE="Requested Range Not Satisfiable",e.RESET_CONTENT="Reset Content",e.SEE_OTHER="See Other",e.SERVICE_UNAVAILABLE="Service Unavailable",e.SWITCHING_PROTOCOLS="Switching Protocols",e.TEMPORARY_REDIRECT="Temporary Redirect",e.TOO_MANY_REQUESTS="Too Many Requests",e.UNAUTHORIZED="Unauthorized",e.UNAVAILABLE_FOR_LEGAL_REASONS="Unavailable For Legal Reasons",e.UNPROCESSABLE_ENTITY="Unprocessable Entity",e.UNSUPPORTED_MEDIA_TYPE="Unsupported Media Type",e.USE_PROXY="Use Proxy",e.MISDIRECTED_REQUEST="Misdirected Request"})(at=U.ReasonPhrases||(U.ReasonPhrases={}))});var Oe=N(l=>{"use strict";var v=l&&l.__assign||function(){return v=Object.assign||function(e){for(var r,t=1,n=arguments.length;t<n;t++){r=arguments[t];for(var i in r)Object.prototype.hasOwnProperty.call(r,i)&&(e[i]=r[i])}return e},v.apply(this,arguments)},ut=l&&l.__createBinding||(Object.create?(function(e,r,t,n){n===void 0&&(n=t),Object.defineProperty(e,n,{enumerable:!0,get:function(){return r[t]}})}):(function(e,r,t,n){n===void 0&&(n=t),e[n]=r[t]})),st=l&&l.__exportStar||function(e,r){for(var t in e)t!=="default"&&!r.hasOwnProperty(t)&&ut(r,e,t)},ct=l&&l.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(l,"__esModule",{value:!0});var Et=ct($()),_e=K(),z=K();Object.defineProperty(l,"getStatusCode",{enumerable:!0,get:function(){return z.getStatusCode}});Object.defineProperty(l,"getReasonPhrase",{enumerable:!0,get:function(){return z.getReasonPhrase}});Object.defineProperty(l,"getStatusText",{enumerable:!0,get:function(){return z.getStatusText}});var lt=pe();Object.defineProperty(l,"StatusCodes",{enumerable:!0,get:function(){return lt.StatusCodes}});var Rt=fe();Object.defineProperty(l,"ReasonPhrases",{enumerable:!0,get:function(){return Rt.ReasonPhrases}});st($(),l);l.default=v(v({},Et.default),{getStatusCode:_e.getStatusCode,getStatusText:_e.getStatusText})});var gt={};je(gt,{ApiGatewayExecutionRouters:()=>xe,ApiGatewayStages:()=>Pe,AwsRegionSchema:()=>Ot,BrowserPipeline:()=>F,CloudFrontDistributions:()=>Le,DEFAULT_CLI_CONFIG:()=>It,DeployStacks:()=>Ce,DynamoDbTables:()=>Me,EnginesBrowserFramework:()=>De,ErrorBoundary:()=>k,ErrorBoundaryNotFound:()=>et,FeaturesConfigSchema:()=>he,IamExecutionRoles:()=>we,LambdaFunctions:()=>ve,PathsConfigSchema:()=>Ue,RuntimeAppServer:()=>le,RuntimeConfigSchema:()=>Nt,RuntimeHeadManager:()=>tt,RuntimeRouter:()=>I,RuntimeRouterProvider:()=>Ze,S3Buckets:()=>be,StageConfigSchema:()=>ye,createRouteLoader:()=>V,createSeoRetriever:()=>Q,executeRuntimeAsync:()=>oe,fetchSeoMetadata:()=>re,getDefaultSeoMeta:()=>W,injectFlow:()=>se,intersection:()=>j,isBrowser:()=>X,isLambdaRuntime:()=>w,isValidServiceName:()=>Se,mergeLoaderResults:()=>ne,routePath:()=>T,routerContext:()=>Z,runtime:()=>pt,runtimeRouter:()=>Je,runtimeThreads:()=>ge,useRuntimeData:()=>qe,useRuntimeSeoMeta:()=>$e});module.exports=ke(gt);var u=f(require("react")),ce=require("react");var G=require("react-router");function qe(){let e=(0,G.useLoaderData)();if(e===void 0)throw new Error("[Runtime] useRuntimeData must be called within a route component with a loader. Ensure the route has a loader function or runtimeAsync retrievers defined.");if(typeof e!="object"||e===null)throw new Error('[Runtime] useRuntimeData received invalid loader data. Expected an object with "internal" and "business" properties.');if(!("business"in e))throw new Error('[Runtime] useRuntimeData received loader data without "business" property. This may indicate the route is not using a Runtime-generated loader.');return e.business}function $e(){let e=(0,G.useLoaderData)();if(e&&!(typeof e!="object"||e===null)&&"internal"in e)return e.internal?.seoMeta}function Ke(e){let r=process.env.PURE_ENV_API_BASE_URL;if(!r)throw new Error("[Runtime] PURE_ENV_API_BASE_URL environment variable is not configured. Please set this variable to your API Gateway base URL.");return`${r.replace(/\/+$/,"")}/seo-meta?route=${encodeURIComponent(e)}`}async function te(e){try{let r=Ke(e),t=await fetch(r);if(!t.ok)return console.warn(`[Runtime] SEO API returned status ${t.status} for route "${e}"`),null;let n=await t.json();return ze(n)}catch(r){return r instanceof Error&&r.message.includes("PURE_ENV_API_BASE_URL")?console.error(r.message):console.warn(`[Runtime] Failed to fetch SEO metadata from API for route "${e}":`,r),null}}function ze(e){return{title:e.title,description:e.description,keywords:e.keywords,ogTitle:e.ogTitle,ogDescription:e.ogDescription,ogImage:e.ogImage,ogUrl:e.canonicalUrl,ogType:"website",twitterCard:"summary",twitterTitle:e.twitterTitle,twitterDescription:e.twitterDescription,twitterImage:e.twitterImage,canonicalUrl:e.canonicalUrl,robots:e.robots}}function Q(e){return async r=>{try{return{seoMeta:await re(e,r)||W()}}catch(t){return console.warn(`[Runtime] SEO retriever failed for route "${e}":`,t),{seoMeta:W()}}}}async function re(e,r){if(typeof window>"u")return null;try{let t=e;return r.params&&Object.entries(r.params).forEach(([n,i])=>{t=t.replace(`:${n}`,String(i))}),await te(t)}catch(t){return console.warn(`[Runtime] Failed to fetch SEO metadata for route "${e}":`,t),null}}function W(){return{title:"Runtime Web Application",description:"A Runtime Web serverless application",robots:"index, follow",keywords:["aws","serverless","react","serverless rendering"],ogTitle:"Runtime Web Application",ogDescription:"A Runtime Web serverless application",ogImage:"/og-image.png",ogUrl:"/",ogType:"website",twitterCard:"summary_large_image",twitterTitle:"Runtime Web Application",twitterDescription:"A Runtime Web serverless application",twitterImage:"/twitter-card.png",canonicalUrl:"/"}}var Y="internal";function V(e,r){return async t=>{let{params:n,request:i}=t,c=new URL(i.url).searchParams,R={params:n,request:i,searchParams:c},m=[{retriever:Q(e),isInternal:!0,name:"Internal SEO retriever"}],d=r.map((He,Be)=>({retriever:He,isInternal:!1,name:`User retriever ${Be+1}`})),E=[...m,...d],Fe=await oe(E,R,e);return ne(Fe,E,e)}}async function oe(e,r,t){if(e.length===0)return[];let n=e.map(({retriever:i})=>i(r));return Promise.allSettled(n)}function ne(e,r,t){let n={internal:{},business:{}};return e.forEach((i,a)=>{let{isInternal:c,name:R}=r[a];if(i.status==="fulfilled"){let m=i.value;if(c)Object.assign(n.internal,m);else if(Y in m){console.warn(`[Runtime] ${R} for route "${t}" returned reserved key "${Y}", ignoring it`);let{[Y]:d,...E}=m;Object.assign(n.business,E)}else Object.assign(n.business,m)}else Xe(i.reason,R,t,c)}),n}function Xe(e,r,t,n){let i;try{i=e instanceof Error?e:new Error(String(e))}catch{try{i=new Error(JSON.stringify(e))}catch{i=new Error("[Unable to serialize error reason]")}}let a=i.message,c=i.stack,R="[Runtime Loader Error]",m={retriever:r,route:t,type:n?"internal":"user",timestamp:new Date().toISOString()};console.warn(`${R} ${r} failed for route "${t}"`,`
2
2
  Error:`,a,`
3
3
  Context:`,m),c&&console.warn(`${R} Stack trace:`,c),typeof process<"u"&&console.warn(`${R} Debug info:`,`
4
4
  - Retriever type:`,n?"Internal framework retriever":"User-provided retriever",`
5
5
  - Route:`,t,`
6
6
  - Error type:`,i.constructor.name,`
7
- - Timestamp:`,m.timestamp)}var ie=f(require("react")),M=require("react"),ae=require("react-router"),Ze=({router:e})=>{let[r,t]=(0,M.useState)(e);return(0,M.useEffect)(()=>{t(e)},[e]),e?ie.createElement(ae.RouterProvider,{key:"runtime-router-provider",router:r}):null};var ue=f(require("react")),_=require("react"),T=e=>"/".concat([...e].join("/")).replace(/\/+/g,"/");function se({children:e,router:r}){return e?r?_.Children.map(e,t=>(0,_.isValidElement)(t)?(t.type?.displayName||t.type?.name)==="RuntimeRouterProvider"?(console.log("[RuntimeRouter] Injecting router instance into RuntimeRouterProvider"),ue.cloneElement(t,{...t.props,router:r})):t.props.children?(0,_.cloneElement)(t,{children:se({children:t.props.children,router:r})}):t:t):(console.warn("[RuntimeRouter] injectFlow called with no router"),_.Children.toArray(e)):(console.warn("[RuntimeRouter] injectFlow called with no children"),[])}function j(e,r){let t=new Set(e),n=new Set(r),i=[];return Array.from(t).forEach(a=>{n.has(a)&&i.push(a)}),i}var I=class{constructor({router:r,defaults:t}){if(!r||!Array.isArray(r)||r.length===0)throw new Error("[RuntimeRouter] Invalid routing configuration: route definitions must be provided as a non-empty array");if(!t)throw new Error("[RuntimeRouter] Invalid configuration: runtime configuration router defaults object is required");this._defaults=t;let n=this.transformRoutes(r),i=Object.keys(this._defaults);this._router=Object.fromEntries(n.map((a,c)=>{a.id||(console.warn(`[RuntimeRouter] Route at index ${c} missing ID, generating one`),a.id=`route-${c}`);let R=Object.keys(a),m=j(i,R);return i.forEach(d=>{m.includes(d)||(a[d]=t[d])}),[a.id,a]})),console.log(`[RuntimeRouter] Routing graph initialized with ${Object.keys(this._router).length} route definition(s)`)}transformRoutes(r){return r.map(t=>this.transformRoute(t))}transformRoute(r){let{path:t,runtimeAsync:n,children:i,index:a,...c}=r,R=T([t??"/"]),m=V(R,n||[]),d=i?this.transformRoutes(i):void 0,E={...c,path:R,loader:m,children:d};return a===!1&&(E.index=!1),E}getRoutes(){return Object.values(this._router)}getRouteById(r){return this._router[r]}getRouteByPath(r){return this.getRoutes().find(t=>t.path===r)}get routes(){return Object.values(this._router)}get defaults(){return this._defaults}};function Je(e){return new I(e)}var k=class extends ce.Component{constructor(t){super(t);this.REDIRECT_TIMEOUT=10;this.isProduction=typeof window>"u"?process.env.PURE_ENV_STAGE==="prod":!1;this.handleReset=()=>{this.clearRedirectInterval(),this.setState({hasError:!1,error:null,errorInfo:null,redirectTimer:this.REDIRECT_TIMEOUT})};this.state={hasError:!1,error:null,errorInfo:null,redirectTimer:this.REDIRECT_TIMEOUT}}static getDerivedStateFromError(t){return{hasError:!0,error:t}}componentDidCatch(t,n){if(console.group("[ErrorBoundary] Error caught"),console.error("Error:",t),console.error("Error Info:",n),console.error("Component Stack:",n.componentStack),console.groupEnd(),this.setState({errorInfo:n}),this.props.onError)try{this.props.onError(t,n)}catch(i){console.error("[ErrorBoundary] Error in custom error handler:",i)}this.startRedirectCountdown()}startRedirectCountdown(){this.redirectInterval=setInterval(()=>{this.setState(t=>{let n=t.redirectTimer-1;return n<=0?(this.clearRedirectInterval(),this.redirectToHome(),{redirectTimer:0}):{redirectTimer:n}})},1e3)}clearRedirectInterval(){this.redirectInterval&&(clearInterval(this.redirectInterval),this.redirectInterval=void 0)}redirectToHome(){window.location.href=T(["/"])}componentWillUnmount(){this.clearRedirectInterval()}render(){if(this.state.hasError){if(this.props.fallback)return this.props.fallback;let t={container:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"100vh",padding:"20px",fontFamily:'-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif',backgroundColor:"#f5f5f5"},content:{maxWidth:"800px",width:"100%",backgroundColor:"#ffffff",borderRadius:"8px",padding:"40px",boxShadow:"0 2px 8px rgba(0, 0, 0, 0.1)"},heading:{fontSize:"2rem",fontWeight:600,textAlign:"center",marginBottom:"20px",color:"#333"},errorBox:{backgroundColor:"#f5f5f5",padding:"16px",borderRadius:"4px",marginBottom:"20px",border:"1px solid #e0e0e0"},errorTitle:{fontSize:"1.125rem",fontWeight:600,color:"#d32f2f",marginBottom:"12px"},errorText:{whiteSpace:"pre-wrap",wordBreak:"break-word",fontFamily:"monospace",fontSize:"0.875rem",color:"#666",maxHeight:"200px",overflow:"auto",margin:0},message:{fontSize:"1rem",textAlign:"center",marginBottom:"16px",color:"#666"},timer:{fontSize:"1rem",textAlign:"center",marginBottom:"24px",color:"#999"},buttonContainer:{display:"flex",justifyContent:"center",gap:"16px",flexWrap:"wrap"},button:{padding:"12px 24px",fontSize:"1rem",fontWeight:500,borderRadius:"4px",border:"none",cursor:"pointer",textDecoration:"none",display:"inline-block",transition:"background-color 0.2s"},primaryButton:{backgroundColor:"#1976d2",color:"#ffffff"},secondaryButton:{backgroundColor:"#ffffff",color:"#1976d2",border:"1px solid #1976d2"}};return u.createElement("div",{style:t.container},u.createElement("div",{style:t.content},u.createElement("h1",{style:t.heading},this.isProduction?"Something went wrong":"An error occurred"),!this.isProduction&&this.state.error&&u.createElement("div",{style:t.errorBox},u.createElement("div",{style:t.errorTitle},"Error Details:"),u.createElement("pre",{style:t.errorText},this.state.error.toString()),this.state.errorInfo&&u.createElement(u.Fragment,null,u.createElement("div",{style:{...t.errorTitle,marginTop:"16px"}},"Component Stack:"),u.createElement("pre",{style:t.errorText},this.state.errorInfo.componentStack))),u.createElement("p",{style:t.message},this.isProduction?"We're sorry for the inconvenience. Please try again.":"Check the console for more details."),this.state.redirectTimer>0&&u.createElement("p",{style:t.timer},`Redirecting to homepage in ${this.state.redirectTimer} seconds`),u.createElement("div",{style:t.buttonContainer},u.createElement("button",{style:{...t.button,...t.primaryButton},onClick:this.handleReset,onMouseOver:n=>{n.currentTarget.style.backgroundColor="#1565c0"},onMouseOut:n=>{n.currentTarget.style.backgroundColor="#1976d2"}},"Try Again"),u.createElement("a",{style:{...t.button,...t.secondaryButton},href:T(["/"]),onMouseOver:n=>{n.currentTarget.style.backgroundColor="#f5f5f5"},onMouseOut:n=>{n.currentTarget.style.backgroundColor="#ffffff"}},"Go to Homepage"))))}return this.props.children}};function et(){let[r,t]=u.useState(10);u.useEffect(()=>{if(r>0){let i=setInterval(()=>{t(a=>a-1)},1e3);return()=>clearInterval(i)}else window.location.href=T(["/"])},[r]);let n={container:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"100vh",padding:"20px",fontFamily:'-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif',backgroundColor:"#f5f5f5"},content:{maxWidth:"800px",width:"100%",backgroundColor:"#ffffff",borderRadius:"8px",padding:"40px",boxShadow:"0 2px 8px rgba(0, 0, 0, 0.1)",textAlign:"center"},heading:{fontSize:"2rem",fontWeight:600,marginBottom:"20px",color:"#333"},message:{fontSize:"1rem",marginBottom:"16px",color:"#666"},link:{color:"#1976d2",textDecoration:"none",fontSize:"1rem",fontWeight:500}};return u.createElement("div",{style:n.container},u.createElement("div",{style:n.content},u.createElement("h1",{style:n.heading},"We couldn't find the page you were looking for."),u.createElement("p",{style:n.message},`We'll take you back to the homepage in ${r} seconds`),u.createElement("p",{style:n.message},u.createElement("a",{href:T(["/"]),style:n.link,onMouseOver:i=>{i.currentTarget.style.textDecoration="underline"},onMouseOut:i=>{i.currentTarget.style.textDecoration="none"}},"Click to go to homepage"))))}var S=require("react"),P=require("react-router"),C=0;function tt(){let e=(0,P.useLocation)(),r=(0,P.useMatches)(),t=(0,S.useRef)(!1);return console.debug("[Runtime] Route change detected, syncing <head> for path: ",e.pathname),(0,S.useEffect)(()=>(t.current||(C++,t.current=!0,C>1&&console.warn(`[Runtime] Multiple RuntimeHeadManager instances detected (${C}). Only one instance should be mounted at the root of your application. Multiple instances may cause unexpected behavior.`)),()=>{t.current&&(C--,t.current=!1)}),[]),(0,S.useEffect)(()=>{if(typeof document>"u"||!document.head){console.warn("[Runtime] document.head is not accessible. Skipping head updates.");return}let a=r[r.length-1]?.data?.internal?.seoMeta;if(!(!a||a===null))try{a.title&&document.title!==a.title&&(document.title=a.title),q("description",a.description),q("keywords",a.keywords?.join(", ")),q("robots",a.robots),A("og:title",a.ogTitle),A("og:description",a.ogDescription),A("og:image",a.ogImage),A("og:url",a.ogUrl),A("og:type",a.ogType),b("twitter:card",a.twitterCard),b("twitter:title",a.twitterTitle),b("twitter:description",a.twitterDescription),b("twitter:image",a.twitterImage),rt("canonical",a.canonicalUrl),ot(a.jsonLd)}catch(c){console.error("[Runtime] Error updating document head:",c)}},[e,r]),null}function q(e,r){try{if(!document.head){console.warn(`[Runtime] Cannot update meta tag "${e}": document.head is not accessible`);return}let t=document.querySelector(`meta[name="${e}"][data-runtime-meta]`);if(t||(t=document.querySelector(`meta[name="${e}"]`)),!r||r===null||r.trim()===""){t&&t.remove();return}let n=L(r);t?t.setAttribute("data-runtime-meta","true"):(t=document.createElement("meta"),t.setAttribute("name",e),t.setAttribute("data-runtime-meta","true"),document.head.appendChild(t)),t.getAttribute("content")!==n&&t.setAttribute("content",n)}catch(t){console.warn(`[Runtime] Failed to update meta tag "${e}":`,t)}}function A(e,r){try{if(!document.head){console.warn(`[Runtime] Cannot update meta property "${e}": document.head is not accessible`);return}let t=document.querySelector(`meta[property="${e}"][data-runtime-meta]`);if(t||(t=document.querySelector(`meta[property="${e}"]`)),!r||r===null||r.trim()===""){t&&t.remove();return}let n=L(r);t?t.setAttribute("data-runtime-meta","true"):(t=document.createElement("meta"),t.setAttribute("property",e),t.setAttribute("data-runtime-meta","true"),document.head.appendChild(t)),t.getAttribute("content")!==n&&t.setAttribute("content",n)}catch(t){console.warn(`[Runtime] Failed to update meta property "${e}":`,t)}}function b(e,r){try{if(!document.head){console.warn(`[Runtime] Cannot update meta name "${e}": document.head is not accessible`);return}let t=document.querySelector(`meta[name="${e}"][data-runtime-meta]`);if(t||(t=document.querySelector(`meta[name="${e}"]`)),!r||r===null||r.trim()===""){t&&t.remove();return}let n=L(r);t?t.setAttribute("data-runtime-meta","true"):(t=document.createElement("meta"),t.setAttribute("name",e),t.setAttribute("data-runtime-meta","true"),document.head.appendChild(t)),t.getAttribute("content")!==n&&t.setAttribute("content",n)}catch(t){console.warn(`[Runtime] Failed to update meta name "${e}":`,t)}}function rt(e,r){try{if(!document.head){console.warn(`[Runtime] Cannot update link tag "${e}": document.head is not accessible`);return}let t=document.querySelector(`link[rel="${e}"][data-runtime-link]`);if(t||(t=document.querySelector(`link[rel="${e}"]`)),!r||r===null||r.trim()===""){t&&t.remove();return}let n=L(r);t?t.setAttribute("data-runtime-link","true"):(t=document.createElement("link"),t.setAttribute("rel",e),t.setAttribute("data-runtime-link","true"),document.head.appendChild(t)),t.getAttribute("href")!==n&&t.setAttribute("href",n)}catch(t){console.warn(`[Runtime] Failed to update link tag "${e}":`,t)}}function ot(e){try{if(!document.head){console.warn("[Runtime] Cannot update JSON-LD: document.head is not accessible");return}let r=document.querySelector("script[data-runtime-jsonld]");if(!e||e===null){r&&r.remove();return}let t=JSON.stringify(e);if(!r)if(r=document.querySelector('script[type="application/ld+json"]'),r&&!r.hasAttribute("data-runtime-jsonld")){r.setAttribute("data-runtime-jsonld","true"),r.textContent!==t&&(r.textContent=t);return}else r||(r=document.createElement("script"),r.setAttribute("type","application/ld+json"),r.setAttribute("data-runtime-jsonld","true"),document.head.appendChild(r));r.textContent!==t&&(r.textContent=t)}catch(r){console.error("[Runtime] Failed to update JSON-LD:",r)}}function L(e){if(!e||e===null)return"";try{let r=document.createElement("div");return r.textContent=e,r.innerHTML}catch(r){return console.warn("[Runtime] DOM-based HTML escaping failed, using fallback:",r),e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#039;")}}var Ee=f(require("react")),D=require("react"),le=({children:e})=>{let[r,t]=(0,D.useState)(!1),[n,i]=(0,D.useState)(!1);return(0,D.useEffect)(()=>{t(!0);let a=setTimeout(()=>{i(!0)},10);return()=>clearTimeout(a)},[]),Ee.createElement("div",{style:{position:r?"relative":"absolute",top:r?"auto":"-9999px",left:r?"auto":"-9999px",visibility:r?"visible":"hidden",pointerEvents:r?"auto":"none",opacity:n?1:0,transition:"opacity 0.6s ease-in-out"}},e)},Re=le;var Ne=f(Oe()),X=typeof window<"u"&&typeof document<"u";function Ie(e,r){if(e.path===r||e.path?.includes(":")&&mt(e.path,r))return{params:dt(e.path,r),pathname:r,route:e,pathnameBase:"/"};if(e.children)for(let t of e.children){let n=Ie(t,r);if(n)return n}return null}function mt(e,r){let t=e.split("/"),n=r.split("/");return t.length!==n.length?!1:t.every((i,a)=>i.startsWith(":")||i===n[a])}function dt(e,r){let t={},n=e.split("/"),i=r.split("/");return n.forEach((a,c)=>{a.startsWith(":")&&(t[a.substring(1)]=i[c])}),t}var Z=(e,r)=>{e.search.length>0&&!e.search.startsWith("?")&&(e.search=`?${e.search}`);let t=e.pathname.includes(process.env.PURE_ENV_STAGE)?e.pathname.replace(`/${process.env.PURE_ENV_STAGE}`,"/"):e.pathname,n=r.routes.map(i=>Ie(i,t)).filter(Boolean);return n.length===0&&console.warn("[Runtime] No matching routes found for:",e.pathname),{basename:"/",matches:n??[],location:e,loaderData:{},actionData:{},errors:n.length===0?{4:{path:`/${Ne.StatusCodes.NOT_FOUND}}`,id:"4",Component:r.defaults.ErrorBoundary,ErrorBoundary:r.defaults.ErrorBoundary,hasErrorBoundary:!0}}:null,statusCode:n.length>0?200:404,loaderHeaders:{},actionHeaders:{}}};var O=f(require("react")),J=require("react-router"),x=require("react-dom/client");function w(){return typeof window>"u"?Object.keys(process.env).some(e=>["AWS_LAMBDA_FUNCTION_NAME","LAMBDA_TASK_ROOT","FUNCTIONS_WORKER_RUNTIME","WEBSITE_INSTANCE_ID","FUNCTION_NAME","K_SERVICE","VERCEL","NETLIFY","FAAS_ENV","__OW_ACTION_NAME"].includes(e)):!1}var Tt="",ge;function pt(e){if(ge={...e},!e)throw new Error("[Runtime] Invalid configuration: runtime threads configuration object is required");if(!e.app||typeof e.app!="function")throw new Error("[Runtime] Invalid configuration: application entry function is required");if(!e.router||!(e.router instanceof I))throw new Error("[Runtime] Invalid configuration: router instance is required");if(console.log("[Runtime] Web runtime initialization started with configuration: ",{hasApp:!!e.app,hasRouter:!!e.router,serviceName:e.config?.serviceName,stage:e.config?.stage}),w()){console.log("[Runtime] Lambda runtime detected, skipping browser rendering pipeline");return}try{ft(e)}catch(r){throw console.error("[Runtime] Web runtime render failed:",r),r}}function ft(e){if(console.log("[Runtime] Web runtime boot sequence started..."),!X){console.warn("[Runtime] Non-browser environment detected, skipping web runtime rendering");return}if(w()){console.warn("[Runtime] Lambda runtime detected, skipping web runtime boot");return}let r=document.getElementById("root-internal"),t=document.getElementById("root-runtime");if(t?.hasChildNodes()){console.log("[Runtime] Pre-rendered DOM snapshot confirmed, binding client runtime...");try{r&&r.remove();try{let d=process.env.PURE_ENV_STAGE}catch{console.warn("\x1B[33m%s\x1B[0m","[WARNING] PURE_ENV_STAGE environment variable is not defined. This may cause unexpected behavior in the application. Please set PURE_ENV_STAGE (e.g., dev, staging, prod)")}let n=process.env.PURE_ENV_STAGE,i=window.location.pathname.includes(n)?window.location.pathname.replace(`/${n}/`,"/"):window.location.pathname;console.log("[Runtime] Route context loaded for:",i);let a={pathname:i,search:window.location.search,hash:window.location.hash||Tt,key:"default",state:null},c=Z(a,e.router);console.log("[Runtime] Routing graph resolved (",c.matches?.length||0,"match(es))");let R=(0,J.createBrowserRouter)(e.router.routes,{hydrationData:c});(0,x.hydrateRoot)(t,O.createElement(Re,null,O.createElement(()=>e.app({router:R}),null)),{onRecoverableError:(d,E)=>{}}),console.log("[Runtime] Web runtime boot sequence finished successfully")}catch(n){throw console.error("[Runtime] Web runtime boot sequence failed:",n),new Error(`[Runtime] Web runtime boot sequence failed: ${n instanceof Error?n.message:String(n)}`)}}else{if(console.log("[Runtime] No pre-rendered DOM snapshot found, creating fresh application root"),!r)throw new Error('[Runtime] Root element "root-internal" not found in DOM. Ensure your HTML includes <div id="root-internal"></div>');try{let n=(0,J.createBrowserRouter)(e.router.getRoutes()),i=(0,x.createRoot)(r),a=()=>e.app({router:n});i.render(O.createElement(O.StrictMode,null,O.createElement(a,null))),console.log("[Runtime] Fresh web runtime render completed successfully")}catch(n){throw console.error("[Runtime] Fresh web runtime render failed:",n),new Error(`[Runtime] Render error details:: ${n instanceof Error?n.message:String(n)}`)}}}var H=f(require("react")),Ae=require("react-dom/client"),B=require("react-router"),F=class{async execute(r,t){try{console.info("Starting browser pipeline execution",{serviceName:r.serviceName,stage:r.stage,url:t.metadata.url,userAgent:t.metadata.userAgent,viewport:t.metadata.viewport});let n=this.createBrowserRouter(r),i=this.createAppElement(r),a=H.createElement(B.RouterProvider,{router:n},i);this.hydrateApplication(a),this.setupHttpClient(r),console.info("Browser pipeline execution completed successfully",{serviceName:r.serviceName,stage:r.stage})}catch(n){throw console.error("Browser pipeline execution failed",{serviceName:r.serviceName,stage:r.stage,error:n instanceof Error?n.message:String(n),stack:n instanceof Error?n.stack:void 0}),n}}createBrowserRouter(r){console.debug("Creating browser router",{routeCount:r.router.getRoutes().length});let t=r.router.getRoutes(),n=(0,B.createBrowserRouter)(t);return console.debug("Browser router created successfully",{routeCount:t.length}),n}createAppElement(r){console.debug("Creating app element from factory");try{let t=r.app({router:r.router});if(!H.isValidElement(t))throw new Error("App factory must return a valid React element");return console.debug("App element created successfully"),t}catch(t){throw console.error("Failed to create app element",{error:t instanceof Error?t.message:String(t)}),new Error(`Failed to create app element: ${t instanceof Error?t.message:String(t)}`)}}hydrateApplication(r){console.debug("Starting React hydration");try{let t=document.getElementById("root");if(!t)throw new Error('Root container element not found. Expected element with id="root"');(0,Ae.hydrateRoot)(t,r),console.info("React hydration completed successfully")}catch(t){throw console.error("React hydration failed",{error:t instanceof Error?t.message:String(t)}),new Error(`React hydration failed: ${t instanceof Error?t.message:String(t)}`)}}setupHttpClient(r){console.debug("Setting up HTTP client for Lambda endpoints");try{let t=this.getApiBaseUrl(r.stage);typeof window<"u"&&(window.__RUNTIME_CONFIG__={serviceName:r.serviceName,stage:r.stage,apiBaseUrl:t}),console.info("HTTP client configured successfully",{baseUrl:t,stage:r.stage})}catch(t){throw console.error("Failed to setup HTTP client",{error:t instanceof Error?t.message:String(t)}),new Error(`Failed to setup HTTP client: ${t instanceof Error?t.message:String(t)}`)}}getApiBaseUrl(r){return`${typeof window<"u"?window.location.origin:""}/api`}};function Se(e){return/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(e)}var De=(E=>(E.React="react",E.Angular="angular",E.Vue="vue",E.Svelte="svelte",E.SvelteKit="sveltekit",E.Solid="solid",E.Polymer="polymer",E.Ember="ember",E.Preact="preact",E.Riot="riot",E))(De||{});var s=require("zod"),_t=["us-east-1","us-east-2","us-west-1","us-west-2","eu-west-1","eu-west-2","eu-west-3","eu-central-1","eu-central-2","eu-north-1","eu-south-1","eu-south-2","ap-southeast-1","ap-southeast-2","ap-southeast-3","ap-south-1","ap-south-2","ap-northeast-1","ap-northeast-2","ap-northeast-3","ap-east-1","sa-east-1","ca-central-1","me-south-1","me-central-1","af-south-1"],Ot=s.z.enum(_t),ye=s.z.object({name:s.z.enum(["dev","staging","prod"]),awsRegion:s.z.string().min(1),awsProfile:s.z.string().optional(),domain:s.z.string().optional(),subdomain:s.z.string().optional()}),Ue=s.z.object({srcDir:s.z.string().default("src"),reactEntry:s.z.string().default("src/index.tsx"),outDir:s.z.string().default("out/dist"),cdkDir:s.z.string().default("cdk").optional()}),he=s.z.object({enableSeo:s.z.boolean().default(!1),enableManifest:s.z.boolean().default(!0),enableWarmup:s.z.boolean().default(!1),clearCacheOnDeploy:s.z.boolean().default(!0)}),Nt=s.z.object({projectName:s.z.string().min(1),stages:s.z.array(ye).min(1),paths:Ue,infraMode:s.z.enum(["cdk","auto"]).default("cdk"),features:he.optional()}),It={projectName:"runtime-web-app",stages:[{name:"dev",awsRegion:"us-east-1"}],paths:{srcDir:"src",reactEntry:"src/index.tsx",outDir:"out/dist",cdkDir:"cdk"},infraMode:"cdk",features:{enableSeo:!1,enableManifest:!0,enableWarmup:!1,clearCacheOnDeploy:!0}};var Me=(r=>(r.RuntimeWebStack="runtime-web-stack",r))(Me||{}),Ce=(r=>(r.SeoEngineDynamoDbEntity="runtime_web_seo_engine",r))(Ce||{}),be=(r=>(r.StaticS3Bucket="runtime_web_static",r))(be||{}),Pe=(r=>(r.RuntimeWebApiGatewayStage="runtime_web_api_gateway_stage",r))(Pe||{}),Le=(r=>(r.CloudFrontDistribution="runtime_web_distribution",r))(Le||{}),ve=(i=>(i.RuntimeWebHandlerLambda="lambdaRuntimeWebHandler",i.RuntimeWebSeoLambda="lambdaRuntimeWebSeoHandler",i.RuntimeWebWarmupLambda="lambdaRuntimeWebWarmupHandler",i.RuntimeWebManifestLambda="lambdaRuntimeWebManifestHandler",i))(ve||{}),we=(r=>(r.RuntimeLambdaExecutionRole="runtime_web_lambda_execution_role",r))(we||{}),xe=(r=>(r.RuntimeWebApiGatewayExecutionRouter="runtime_web_api_gateway_execution_router",r))(xe||{});0&&(module.exports={ApiGatewayExecutionRouters,ApiGatewayStages,AwsRegionSchema,BrowserPipeline,CloudFrontDistributions,DEFAULT_CLI_CONFIG,DeployStacks,DynamoDbTables,EnginesBrowserFramework,ErrorBoundary,ErrorBoundaryNotFound,FeaturesConfigSchema,IamExecutionRoles,LambdaFunctions,PathsConfigSchema,RuntimeAppServer,RuntimeConfigSchema,RuntimeHeadManager,RuntimeRouter,RuntimeRouterProvider,S3Buckets,StageConfigSchema,createRouteLoader,createSeoRetriever,executeRuntimeAsync,fetchSeoMetadata,getDefaultSeoMeta,injectFlow,intersection,isBrowser,isLambdaRuntime,isValidServiceName,mergeLoaderResults,routePath,routerContext,runtime,runtimeRouter,runtimeThreads,useRuntimeData,useRuntimeSeoMeta});
7
+ - Timestamp:`,m.timestamp)}var ie=f(require("react")),C=require("react"),ae=require("react-router"),Ze=({router:e})=>{let[r,t]=(0,C.useState)(e);return(0,C.useEffect)(()=>{t(e)},[e]),e?ie.createElement(ae.RouterProvider,{key:"runtime-router-provider",router:r}):null};var ue=f(require("react")),_=require("react"),T=e=>"/".concat([...e].join("/")).replace(/\/+/g,"/");function se({children:e,router:r}){return e?r?_.Children.map(e,t=>(0,_.isValidElement)(t)?(t.type?.displayName||t.type?.name)==="RuntimeRouterProvider"?(console.log("[RuntimeRouter] Injecting router instance into RuntimeRouterProvider"),ue.cloneElement(t,{...t.props,router:r})):t.props.children?(0,_.cloneElement)(t,{children:se({children:t.props.children,router:r})}):t:t):(console.warn("[RuntimeRouter] injectFlow called with no router"),_.Children.toArray(e)):(console.warn("[RuntimeRouter] injectFlow called with no children"),[])}function j(e,r){let t=new Set(e),n=new Set(r),i=[];return Array.from(t).forEach(a=>{n.has(a)&&i.push(a)}),i}var I=class{constructor({router:r,defaults:t}){if(!r||!Array.isArray(r)||r.length===0)throw new Error("[RuntimeRouter] Invalid routing configuration: route definitions must be provided as a non-empty array");if(!t)throw new Error("[RuntimeRouter] Invalid configuration: runtime configuration router defaults object is required");this._defaults=t;let n=this.transformRoutes(r),i=Object.keys(this._defaults);this._router=Object.fromEntries(n.map((a,c)=>{a.id||(console.warn(`[RuntimeRouter] Route at index ${c} missing ID, generating one`),a.id=`route-${c}`);let R=Object.keys(a),m=j(i,R);return i.forEach(d=>{m.includes(d)||(a[d]=t[d])}),[a.id,a]})),console.log(`[RuntimeRouter] Routing graph initialized with ${Object.keys(this._router).length} route definition(s)`)}transformRoutes(r){return r.map(t=>this.transformRoute(t))}transformRoute(r){let{path:t,runtimeAsync:n,children:i,index:a,...c}=r,R=T([t??"/"]),m=V(R,n||[]),d=i?this.transformRoutes(i):void 0,E={...c,path:R,loader:m,children:d};return a===!1&&(E.index=!1),E}getRoutes(){return Object.values(this._router)}getRouteById(r){return this._router[r]}getRouteByPath(r){return this.getRoutes().find(t=>t.path===r)}get routes(){return Object.values(this._router)}get defaults(){return this._defaults}};function Je(e){return new I(e)}var k=class extends ce.Component{constructor(t){super(t);this.REDIRECT_TIMEOUT=10;this.isProduction=typeof window>"u"?process.env.PURE_ENV_STAGE==="prod":!1;this.handleReset=()=>{this.clearRedirectInterval(),this.setState({hasError:!1,error:null,errorInfo:null,redirectTimer:this.REDIRECT_TIMEOUT})};this.state={hasError:!1,error:null,errorInfo:null,redirectTimer:this.REDIRECT_TIMEOUT}}static getDerivedStateFromError(t){return{hasError:!0,error:t}}componentDidCatch(t,n){if(console.group("[ErrorBoundary] Error caught"),console.error("Error:",t),console.error("Error Info:",n),console.error("Component Stack:",n.componentStack),console.groupEnd(),this.setState({errorInfo:n}),this.props.onError)try{this.props.onError(t,n)}catch(i){console.error("[ErrorBoundary] Error in custom error handler:",i)}this.startRedirectCountdown()}startRedirectCountdown(){this.redirectInterval=setInterval(()=>{this.setState(t=>{let n=t.redirectTimer-1;return n<=0?(this.clearRedirectInterval(),this.redirectToHome(),{redirectTimer:0}):{redirectTimer:n}})},1e3)}clearRedirectInterval(){this.redirectInterval&&(clearInterval(this.redirectInterval),this.redirectInterval=void 0)}redirectToHome(){window.location.href=T(["/"])}componentWillUnmount(){this.clearRedirectInterval()}render(){if(this.state.hasError){if(this.props.fallback)return this.props.fallback;let t={container:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"100vh",padding:"20px",fontFamily:'-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif',backgroundColor:"#f5f5f5"},content:{maxWidth:"800px",width:"100%",backgroundColor:"#ffffff",borderRadius:"8px",padding:"40px",boxShadow:"0 2px 8px rgba(0, 0, 0, 0.1)"},heading:{fontSize:"2rem",fontWeight:600,textAlign:"center",marginBottom:"20px",color:"#333"},errorBox:{backgroundColor:"#f5f5f5",padding:"16px",borderRadius:"4px",marginBottom:"20px",border:"1px solid #e0e0e0"},errorTitle:{fontSize:"1.125rem",fontWeight:600,color:"#d32f2f",marginBottom:"12px"},errorText:{whiteSpace:"pre-wrap",wordBreak:"break-word",fontFamily:"monospace",fontSize:"0.875rem",color:"#666",maxHeight:"200px",overflow:"auto",margin:0},message:{fontSize:"1rem",textAlign:"center",marginBottom:"16px",color:"#666"},timer:{fontSize:"1rem",textAlign:"center",marginBottom:"24px",color:"#999"},buttonContainer:{display:"flex",justifyContent:"center",gap:"16px",flexWrap:"wrap"},button:{padding:"12px 24px",fontSize:"1rem",fontWeight:500,borderRadius:"4px",border:"none",cursor:"pointer",textDecoration:"none",display:"inline-block",transition:"background-color 0.2s"},primaryButton:{backgroundColor:"#1976d2",color:"#ffffff"},secondaryButton:{backgroundColor:"#ffffff",color:"#1976d2",border:"1px solid #1976d2"}};return u.createElement("div",{style:t.container},u.createElement("div",{style:t.content},u.createElement("h1",{style:t.heading},this.isProduction?"Something went wrong":"An error occurred"),!this.isProduction&&this.state.error&&u.createElement("div",{style:t.errorBox},u.createElement("div",{style:t.errorTitle},"Error Details:"),u.createElement("pre",{style:t.errorText},this.state.error.toString()),this.state.errorInfo&&u.createElement(u.Fragment,null,u.createElement("div",{style:{...t.errorTitle,marginTop:"16px"}},"Component Stack:"),u.createElement("pre",{style:t.errorText},this.state.errorInfo.componentStack))),u.createElement("p",{style:t.message},this.isProduction?"We're sorry for the inconvenience. Please try again.":"Check the console for more details."),this.state.redirectTimer>0&&u.createElement("p",{style:t.timer},`Redirecting to homepage in ${this.state.redirectTimer} seconds`),u.createElement("div",{style:t.buttonContainer},u.createElement("button",{style:{...t.button,...t.primaryButton},onClick:this.handleReset,onMouseOver:n=>{n.currentTarget.style.backgroundColor="#1565c0"},onMouseOut:n=>{n.currentTarget.style.backgroundColor="#1976d2"}},"Try Again"),u.createElement("a",{style:{...t.button,...t.secondaryButton},href:T(["/"]),onMouseOver:n=>{n.currentTarget.style.backgroundColor="#f5f5f5"},onMouseOut:n=>{n.currentTarget.style.backgroundColor="#ffffff"}},"Go to Homepage"))))}return this.props.children}};function et(){let[r,t]=u.useState(10);u.useEffect(()=>{if(r>0){let i=setInterval(()=>{t(a=>a-1)},1e3);return()=>clearInterval(i)}else window.location.href=T(["/"])},[r]);let n={container:{display:"flex",justifyContent:"center",alignItems:"center",minHeight:"100vh",padding:"20px",fontFamily:'-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif',backgroundColor:"#f5f5f5"},content:{maxWidth:"800px",width:"100%",backgroundColor:"#ffffff",borderRadius:"8px",padding:"40px",boxShadow:"0 2px 8px rgba(0, 0, 0, 0.1)",textAlign:"center"},heading:{fontSize:"2rem",fontWeight:600,marginBottom:"20px",color:"#333"},message:{fontSize:"1rem",marginBottom:"16px",color:"#666"},link:{color:"#1976d2",textDecoration:"none",fontSize:"1rem",fontWeight:500}};return u.createElement("div",{style:n.container},u.createElement("div",{style:n.content},u.createElement("h1",{style:n.heading},"We couldn't find the page you were looking for."),u.createElement("p",{style:n.message},`We'll take you back to the homepage in ${r} seconds`),u.createElement("p",{style:n.message},u.createElement("a",{href:T(["/"]),style:n.link,onMouseOver:i=>{i.currentTarget.style.textDecoration="underline"},onMouseOut:i=>{i.currentTarget.style.textDecoration="none"}},"Click to go to homepage"))))}var S=require("react"),P=require("react-router"),M=0;function tt(){let e=(0,P.useLocation)(),r=(0,P.useMatches)(),t=(0,S.useRef)(!1);return console.debug("[Runtime] Route change detected, syncing <head> for path: ",e.pathname),(0,S.useEffect)(()=>(t.current||(M++,t.current=!0,M>1&&console.warn(`[Runtime] Multiple RuntimeHeadManager instances detected (${M}). Only one instance should be mounted at the root of your application. Multiple instances may cause unexpected behavior.`)),()=>{t.current&&(M--,t.current=!1)}),[]),(0,S.useEffect)(()=>{if(typeof document>"u"||!document.head){console.warn("[Runtime] document.head is not accessible. Skipping head updates.");return}let a=r[r.length-1]?.data?.internal?.seoMeta;if(!(!a||a===null))try{a.title&&document.title!==a.title&&(document.title=a.title),q("description",a.description),q("keywords",a.keywords?.join(", ")),q("robots",a.robots),A("og:title",a.ogTitle),A("og:description",a.ogDescription),A("og:image",a.ogImage),A("og:url",a.ogUrl),A("og:type",a.ogType),b("twitter:card",a.twitterCard),b("twitter:title",a.twitterTitle),b("twitter:description",a.twitterDescription),b("twitter:image",a.twitterImage),rt("canonical",a.canonicalUrl),ot(a.jsonLd)}catch(c){console.error("[Runtime] Error updating document head:",c)}},[e,r]),null}function q(e,r){try{if(!document.head){console.warn(`[Runtime] Cannot update meta tag "${e}": document.head is not accessible`);return}let t=document.querySelector(`meta[name="${e}"][data-runtime-meta]`);if(t||(t=document.querySelector(`meta[name="${e}"]`)),!r||r===null||r.trim()===""){t&&t.remove();return}let n=L(r);t?t.setAttribute("data-runtime-meta","true"):(t=document.createElement("meta"),t.setAttribute("name",e),t.setAttribute("data-runtime-meta","true"),document.head.appendChild(t)),t.getAttribute("content")!==n&&t.setAttribute("content",n)}catch(t){console.warn(`[Runtime] Failed to update meta tag "${e}":`,t)}}function A(e,r){try{if(!document.head){console.warn(`[Runtime] Cannot update meta property "${e}": document.head is not accessible`);return}let t=document.querySelector(`meta[property="${e}"][data-runtime-meta]`);if(t||(t=document.querySelector(`meta[property="${e}"]`)),!r||r===null||r.trim()===""){t&&t.remove();return}let n=L(r);t?t.setAttribute("data-runtime-meta","true"):(t=document.createElement("meta"),t.setAttribute("property",e),t.setAttribute("data-runtime-meta","true"),document.head.appendChild(t)),t.getAttribute("content")!==n&&t.setAttribute("content",n)}catch(t){console.warn(`[Runtime] Failed to update meta property "${e}":`,t)}}function b(e,r){try{if(!document.head){console.warn(`[Runtime] Cannot update meta name "${e}": document.head is not accessible`);return}let t=document.querySelector(`meta[name="${e}"][data-runtime-meta]`);if(t||(t=document.querySelector(`meta[name="${e}"]`)),!r||r===null||r.trim()===""){t&&t.remove();return}let n=L(r);t?t.setAttribute("data-runtime-meta","true"):(t=document.createElement("meta"),t.setAttribute("name",e),t.setAttribute("data-runtime-meta","true"),document.head.appendChild(t)),t.getAttribute("content")!==n&&t.setAttribute("content",n)}catch(t){console.warn(`[Runtime] Failed to update meta name "${e}":`,t)}}function rt(e,r){try{if(!document.head){console.warn(`[Runtime] Cannot update link tag "${e}": document.head is not accessible`);return}let t=document.querySelector(`link[rel="${e}"][data-runtime-link]`);if(t||(t=document.querySelector(`link[rel="${e}"]`)),!r||r===null||r.trim()===""){t&&t.remove();return}let n=L(r);t?t.setAttribute("data-runtime-link","true"):(t=document.createElement("link"),t.setAttribute("rel",e),t.setAttribute("data-runtime-link","true"),document.head.appendChild(t)),t.getAttribute("href")!==n&&t.setAttribute("href",n)}catch(t){console.warn(`[Runtime] Failed to update link tag "${e}":`,t)}}function ot(e){try{if(!document.head){console.warn("[Runtime] Cannot update JSON-LD: document.head is not accessible");return}let r=document.querySelector("script[data-runtime-jsonld]");if(!e||e===null){r&&r.remove();return}let t=JSON.stringify(e);if(!r)if(r=document.querySelector('script[type="application/ld+json"]'),r&&!r.hasAttribute("data-runtime-jsonld")){r.setAttribute("data-runtime-jsonld","true"),r.textContent!==t&&(r.textContent=t);return}else r||(r=document.createElement("script"),r.setAttribute("type","application/ld+json"),r.setAttribute("data-runtime-jsonld","true"),document.head.appendChild(r));r.textContent!==t&&(r.textContent=t)}catch(r){console.error("[Runtime] Failed to update JSON-LD:",r)}}function L(e){if(!e||e===null)return"";try{let r=document.createElement("div");return r.textContent=e,r.innerHTML}catch(r){return console.warn("[Runtime] DOM-based HTML escaping failed, using fallback:",r),e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#039;")}}var Ee=f(require("react")),D=require("react"),le=({children:e})=>{let[r,t]=(0,D.useState)(!1),[n,i]=(0,D.useState)(!1);return(0,D.useEffect)(()=>{t(!0);let a=setTimeout(()=>{i(!0)},10);return()=>clearTimeout(a)},[]),Ee.createElement("div",{style:{position:r?"relative":"absolute",top:r?"auto":"-9999px",left:r?"auto":"-9999px",visibility:r?"visible":"hidden",pointerEvents:r?"auto":"none",opacity:n?1:0,transition:"opacity 0.6s ease-in-out"}},e)},Re=le;var Ne=f(Oe()),X=typeof window<"u"&&typeof document<"u";function Ie(e,r){if(e.path===r||e.path?.includes(":")&&mt(e.path,r))return{params:dt(e.path,r),pathname:r,route:e,pathnameBase:"/"};if(e.children)for(let t of e.children){let n=Ie(t,r);if(n)return n}return null}function mt(e,r){let t=e.split("/"),n=r.split("/");return t.length!==n.length?!1:t.every((i,a)=>i.startsWith(":")||i===n[a])}function dt(e,r){let t={},n=e.split("/"),i=r.split("/");return n.forEach((a,c)=>{a.startsWith(":")&&(t[a.substring(1)]=i[c])}),t}var Z=(e,r)=>{e.search.length>0&&!e.search.startsWith("?")&&(e.search=`?${e.search}`);let t=e.pathname.includes(process.env.PURE_ENV_STAGE)?e.pathname.replace(`/${process.env.PURE_ENV_STAGE}`,"/"):e.pathname,n=r.routes.map(i=>Ie(i,t)).filter(Boolean);return n.length===0&&console.warn("[Runtime] No matching routes found for:",e.pathname),{basename:"/",matches:n??[],location:e,loaderData:{},actionData:{},errors:n.length===0?{4:{path:`/${Ne.StatusCodes.NOT_FOUND}}`,id:"4",Component:r.defaults.ErrorBoundary,ErrorBoundary:r.defaults.ErrorBoundary,hasErrorBoundary:!0}}:null,statusCode:n.length>0?200:404,loaderHeaders:{},actionHeaders:{}}};var O=f(require("react")),J=require("react-router"),x=require("react-dom/client");function w(){return typeof window>"u"?Object.keys(process.env).some(e=>["AWS_LAMBDA_FUNCTION_NAME","LAMBDA_TASK_ROOT","FUNCTIONS_WORKER_RUNTIME","WEBSITE_INSTANCE_ID","FUNCTION_NAME","K_SERVICE","VERCEL","NETLIFY","FAAS_ENV","__OW_ACTION_NAME"].includes(e)):!1}var Tt="",ge;function pt(e){if(ge={...e},!e)throw new Error("[Runtime] Invalid configuration: runtime threads configuration object is required");if(!e.app||typeof e.app!="function")throw new Error("[Runtime] Invalid configuration: application entry function is required");if(!e.router||!(e.router instanceof I))throw new Error("[Runtime] Invalid configuration: router instance is required");if(console.log("[Runtime] Web runtime initialization started with configuration: ",{hasApp:!!e.app,hasRouter:!!e.router,serviceName:e.config?.serviceName,stage:e.config?.stage}),w()){console.log("[Runtime] Lambda runtime detected, skipping browser rendering pipeline");return}try{ft(e)}catch(r){throw console.error("[Runtime] Web runtime render failed:",r),r}}function ft(e){if(console.log("[Runtime] Web runtime boot sequence started..."),!X){console.warn("[Runtime] Non-browser environment detected, skipping web runtime rendering");return}if(w()){console.warn("[Runtime] Lambda runtime detected, skipping web runtime boot");return}let r=document.getElementById("root-internal"),t=document.getElementById("root-runtime");if(t?.hasChildNodes()){console.log("[Runtime] Pre-rendered DOM snapshot confirmed, binding client runtime...");try{r&&r.remove();try{let d=process.env.PURE_ENV_STAGE}catch{console.warn("\x1B[33m%s\x1B[0m","[WARNING] PURE_ENV_STAGE environment variable is not defined. This may cause unexpected behavior in the application. Please set PURE_ENV_STAGE (e.g., dev, staging, prod)")}let n=process.env.PURE_ENV_STAGE,i=window.location.pathname.includes(n)?window.location.pathname.replace(`/${n}/`,"/"):window.location.pathname;console.log("[Runtime] Route context loaded for:",i);let a={pathname:i,search:window.location.search,hash:window.location.hash||Tt,key:"default",state:null},c=Z(a,e.router);console.log("[Runtime] Routing graph resolved (",c.matches?.length||0,"match(es))");let R=(0,J.createBrowserRouter)(e.router.routes,{hydrationData:c});(0,x.hydrateRoot)(t,O.createElement(Re,null,O.createElement(()=>e.app({router:R}),null)),{onRecoverableError:(d,E)=>{}}),console.log("[Runtime] Web runtime boot sequence finished successfully")}catch(n){throw console.error("[Runtime] Web runtime boot sequence failed:",n),new Error(`[Runtime] Web runtime boot sequence failed: ${n instanceof Error?n.message:String(n)}`)}}else{if(console.log("[Runtime] No pre-rendered DOM snapshot found, creating fresh application root"),!r)throw new Error('[Runtime] Root element "root-internal" not found in DOM. Ensure your HTML includes <div id="root-internal"></div>');try{let n=(0,J.createBrowserRouter)(e.router.getRoutes()),i=(0,x.createRoot)(r),a=()=>e.app({router:n});i.render(O.createElement(O.StrictMode,null,O.createElement(a,null))),console.log("[Runtime] Fresh web runtime render completed successfully")}catch(n){throw console.error("[Runtime] Fresh web runtime render failed:",n),new Error(`[Runtime] Render error details:: ${n instanceof Error?n.message:String(n)}`)}}}var H=f(require("react")),Ae=require("react-dom/client"),B=require("react-router"),F=class{async execute(r,t){try{console.info("Starting browser pipeline execution",{serviceName:r.serviceName,stage:r.stage,url:t.metadata.url,userAgent:t.metadata.userAgent,viewport:t.metadata.viewport});let n=this.createBrowserRouter(r),i=this.createAppElement(r),a=H.createElement(B.RouterProvider,{router:n},i);this.hydrateApplication(a),this.setupHttpClient(r),console.info("Browser pipeline execution completed successfully",{serviceName:r.serviceName,stage:r.stage})}catch(n){throw console.error("Browser pipeline execution failed",{serviceName:r.serviceName,stage:r.stage,error:n instanceof Error?n.message:String(n),stack:n instanceof Error?n.stack:void 0}),n}}createBrowserRouter(r){console.debug("Creating browser router",{routeCount:r.router.getRoutes().length});let t=r.router.getRoutes(),n=(0,B.createBrowserRouter)(t);return console.debug("Browser router created successfully",{routeCount:t.length}),n}createAppElement(r){console.debug("Creating app element from factory");try{let t=r.app({router:r.router});if(!H.isValidElement(t))throw new Error("App factory must return a valid React element");return console.debug("App element created successfully"),t}catch(t){throw console.error("Failed to create app element",{error:t instanceof Error?t.message:String(t)}),new Error(`Failed to create app element: ${t instanceof Error?t.message:String(t)}`)}}hydrateApplication(r){console.debug("Starting React hydration");try{let t=document.getElementById("root");if(!t)throw new Error('Root container element not found. Expected element with id="root"');(0,Ae.hydrateRoot)(t,r),console.info("React hydration completed successfully")}catch(t){throw console.error("React hydration failed",{error:t instanceof Error?t.message:String(t)}),new Error(`React hydration failed: ${t instanceof Error?t.message:String(t)}`)}}setupHttpClient(r){console.debug("Setting up HTTP client for Lambda endpoints");try{let t=this.getApiBaseUrl(r.stage);typeof window<"u"&&(window.__RUNTIME_CONFIG__={serviceName:r.serviceName,stage:r.stage,apiBaseUrl:t}),console.info("HTTP client configured successfully",{baseUrl:t,stage:r.stage})}catch(t){throw console.error("Failed to setup HTTP client",{error:t instanceof Error?t.message:String(t)}),new Error(`Failed to setup HTTP client: ${t instanceof Error?t.message:String(t)}`)}}getApiBaseUrl(r){return`${typeof window<"u"?window.location.origin:""}/api`}};function Se(e){return/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(e)}var De=(E=>(E.React="react",E.Angular="angular",E.Vue="vue",E.Svelte="svelte",E.SvelteKit="sveltekit",E.Solid="solid",E.Polymer="polymer",E.Ember="ember",E.Preact="preact",E.Riot="riot",E))(De||{});var s=require("zod"),_t=["us-east-1","us-east-2","us-west-1","us-west-2","eu-west-1","eu-west-2","eu-west-3","eu-central-1","eu-central-2","eu-north-1","eu-south-1","eu-south-2","ap-southeast-1","ap-southeast-2","ap-southeast-3","ap-south-1","ap-south-2","ap-northeast-1","ap-northeast-2","ap-northeast-3","ap-east-1","sa-east-1","ca-central-1","me-south-1","me-central-1","af-south-1"],Ot=s.z.enum(_t),ye=s.z.object({name:s.z.enum(["dev","staging","prod"]),awsRegion:s.z.string().min(1),awsProfile:s.z.string().optional(),domain:s.z.string().optional(),subdomain:s.z.string().optional()}),Ue=s.z.object({srcDir:s.z.string().default("src"),reactEntry:s.z.string().default("src/index.tsx"),outDir:s.z.string().default("out/dist"),cdkDir:s.z.string().default("cdk").optional()}),he=s.z.object({enableSeo:s.z.boolean().default(!1),enableManifest:s.z.boolean().default(!0),enableWarmup:s.z.boolean().default(!1),clearCacheOnDeploy:s.z.boolean().default(!0)}),Nt=s.z.object({projectName:s.z.string().min(1),stages:s.z.array(ye).min(1),paths:Ue,infraMode:s.z.enum(["cdk","auto"]).default("cdk"),features:he.optional()}),It={projectName:"runtime-web-app",stages:[{name:"dev",awsRegion:"us-east-1"}],paths:{srcDir:"src",reactEntry:"src/index.tsx",outDir:"out/dist",cdkDir:"cdk"},infraMode:"cdk",features:{enableSeo:!1,enableManifest:!0,enableWarmup:!1,clearCacheOnDeploy:!0}};var Ce=(r=>(r.RuntimeWebStack="runtime-web-stack",r))(Ce||{}),Me=(r=>(r.SeoEngineDynamoDbEntity="runtime_web_seo_engine",r))(Me||{}),be=(r=>(r.StaticS3Bucket="runtime_web_static",r))(be||{}),Pe=(r=>(r.RuntimeWebApiGatewayStage="runtime_web_api_gateway_stage",r))(Pe||{}),Le=(r=>(r.CloudFrontDistribution="runtime_web_distribution",r))(Le||{}),ve=(i=>(i.RuntimeWebHandlerLambda="lambdaRuntimeWebHandler",i.RuntimeWebSeoLambda="lambdaRuntimeWebSeoHandler",i.RuntimeWebWarmupLambda="lambdaRuntimeWebWarmupHandler",i.RuntimeWebManifestLambda="lambdaRuntimeWebManifestHandler",i))(ve||{}),we=(r=>(r.RuntimeLambdaExecutionRole="runtime_web_lambda_execution_role",r))(we||{}),xe=(r=>(r.RuntimeWebApiGatewayExecutionRouter="runtime_web_api_gateway_execution_router",r))(xe||{});0&&(module.exports={ApiGatewayExecutionRouters,ApiGatewayStages,AwsRegionSchema,BrowserPipeline,CloudFrontDistributions,DEFAULT_CLI_CONFIG,DeployStacks,DynamoDbTables,EnginesBrowserFramework,ErrorBoundary,ErrorBoundaryNotFound,FeaturesConfigSchema,IamExecutionRoles,LambdaFunctions,PathsConfigSchema,RuntimeAppServer,RuntimeConfigSchema,RuntimeHeadManager,RuntimeRouter,RuntimeRouterProvider,S3Buckets,StageConfigSchema,createRouteLoader,createSeoRetriever,executeRuntimeAsync,fetchSeoMetadata,getDefaultSeoMeta,injectFlow,intersection,isBrowser,isLambdaRuntime,isValidServiceName,mergeLoaderResults,routePath,routerContext,runtime,runtimeRouter,runtimeThreads,useRuntimeData,useRuntimeSeoMeta});
8
8
  //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../../../node_modules/http-status-codes/build/cjs/legacy.js", "../../../../../node_modules/http-status-codes/build/cjs/utils.js", "../../../../../node_modules/http-status-codes/build/cjs/utils-functions.js", "../../../../../node_modules/http-status-codes/build/cjs/status-codes.js", "../../../../../node_modules/http-status-codes/build/cjs/reason-phrases.js", "../../../../../node_modules/http-status-codes/build/cjs/index.js", "../../../src/index.tsx", "../../../src/lib/runtime-core/components/error.boundary/index.tsx", "../../../src/lib/runtime-core/runtime.router/runtime.router.hooks.ts", "../../../src/lib/runtime-core/runtime.router/runtime.router.seo.api-client.ts", "../../../src/lib/runtime-core/runtime.router/runtime.router.seo.ts", "../../../src/lib/runtime-core/runtime.router/runtime.router.loader.ts", "../../../src/lib/runtime-core/runtime.router/runtime.router.provider.tsx", "../../../src/lib/runtime-core/runtime.router/runtime.router.utils.tsx", "../../../src/lib/runtime-core/runtime.router/runtime.router.tsx", "../../../src/lib/runtime-core/components/runtime-web-head-manager.tsx", "../../../src/lib/runtime-core/runtime.app.server.tsx", "../../../src/lib/runtime-core/react.utils.tsx", "../../../src/lib/runtime-core/runtime.tsx", "../../../src/lib/runtime-core/runtime.utils.tsx", "../../../src/lib/runtime-web/pipelines/browser-pipeline.ts", "../../../src/lib/runtime-web/types/runtime-web.config.types.ts", "../../../src/lib/runtime.types.tsx", "../../../src/utils/types/runtime.config.ts", "../../../src/utils/types/clouds/clouds.aws.types.ts"],
  "sourcesContent": ["\"use strict\";\n// Exporting constants directly to maintain compatability with v1\n// These are deprecated. Please don't add any new codes here.\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.USE_PROXY = exports.UNSUPPORTED_MEDIA_TYPE = exports.UNPROCESSABLE_ENTITY = exports.UNAUTHORIZED = exports.TOO_MANY_REQUESTS = exports.TEMPORARY_REDIRECT = exports.SWITCHING_PROTOCOLS = exports.SERVICE_UNAVAILABLE = exports.SEE_OTHER = exports.RESET_CONTENT = exports.REQUESTED_RANGE_NOT_SATISFIABLE = exports.REQUEST_URI_TOO_LONG = exports.REQUEST_TOO_LONG = exports.REQUEST_TIMEOUT = exports.REQUEST_HEADER_FIELDS_TOO_LARGE = exports.PROXY_AUTHENTICATION_REQUIRED = exports.PROCESSING = exports.PRECONDITION_REQUIRED = exports.PRECONDITION_FAILED = exports.PERMANENT_REDIRECT = exports.PAYMENT_REQUIRED = exports.PARTIAL_CONTENT = exports.OK = exports.NOT_MODIFIED = exports.NOT_IMPLEMENTED = exports.NOT_FOUND = exports.NOT_ACCEPTABLE = exports.NON_AUTHORITATIVE_INFORMATION = exports.NO_CONTENT = exports.NETWORK_AUTHENTICATION_REQUIRED = exports.MULTIPLE_CHOICES = exports.MULTI_STATUS = exports.MOVED_TEMPORARILY = exports.MOVED_PERMANENTLY = exports.METHOD_NOT_ALLOWED = exports.METHOD_FAILURE = exports.LOCKED = exports.LENGTH_REQUIRED = exports.INTERNAL_SERVER_ERROR = exports.INSUFFICIENT_STORAGE = exports.INSUFFICIENT_SPACE_ON_RESOURCE = exports.IM_A_TEAPOT = exports.HTTP_VERSION_NOT_SUPPORTED = exports.GONE = exports.GATEWAY_TIMEOUT = exports.FORBIDDEN = exports.FAILED_DEPENDENCY = exports.EXPECTATION_FAILED = exports.CREATED = exports.CONTINUE = exports.CONFLICT = exports.BAD_REQUEST = exports.BAD_GATEWAY = exports.ACCEPTED = void 0;\n/**\n * @deprecated Please use StatusCodes.ACCEPTED\n *\n * */\nexports.ACCEPTED = 202;\n/**\n * @deprecated Please use StatusCodes.BAD_GATEWAY\n *\n * */\nexports.BAD_GATEWAY = 502;\n/**\n * @deprecated Please use StatusCodes.BAD_REQUEST\n *\n * */\nexports.BAD_REQUEST = 400;\n/**\n * @deprecated Please use StatusCodes.CONFLICT\n *\n * */\nexports.CONFLICT = 409;\n/**\n * @deprecated Please use StatusCodes.CONTINUE\n *\n * */\nexports.CONTINUE = 100;\n/**\n * @deprecated Please use StatusCodes.CREATED\n *\n * */\nexports.CREATED = 201;\n/**\n * @deprecated Please use StatusCodes.EXPECTATION_FAILED\n *\n * */\nexports.EXPECTATION_FAILED = 417;\n/**\n * @deprecated Please use StatusCodes.FAILED_DEPENDENCY\n *\n * */\nexports.FAILED_DEPENDENCY = 424;\n/**\n * @deprecated Please use StatusCodes.FORBIDDEN\n *\n * */\nexports.FORBIDDEN = 403;\n/**\n * @deprecated Please use StatusCodes.GATEWAY_TIMEOUT\n *\n * */\nexports.GATEWAY_TIMEOUT = 504;\n/**\n * @deprecated Please use StatusCodes.GONE\n *\n * */\nexports.GONE = 410;\n/**\n * @deprecated Please use StatusCodes.HTTP_VERSION_NOT_SUPPORTED\n *\n * */\nexports.HTTP_VERSION_NOT_SUPPORTED = 505;\n/**\n * @deprecated Please use StatusCodes.IM_A_TEAPOT\n *\n * */\nexports.IM_A_TEAPOT = 418;\n/**\n * @deprecated Please use StatusCodes.INSUFFICIENT_SPACE_ON_RESOURCE\n *\n * */\nexports.INSUFFICIENT_SPACE_ON_RESOURCE = 419;\n/**\n * @deprecated Please use StatusCodes.INSUFFICIENT_STORAGE\n *\n * */\nexports.INSUFFICIENT_STORAGE = 507;\n/**\n * @deprecated Please use StatusCodes.INTERNAL_SERVER_ERROR\n *\n * */\nexports.INTERNAL_SERVER_ERROR = 500;\n/**\n * @deprecated Please use StatusCodes.LENGTH_REQUIRED\n *\n * */\nexports.LENGTH_REQUIRED = 411;\n/**\n * @deprecated Please use StatusCodes.LOCKED\n *\n * */\nexports.LOCKED = 423;\n/**\n * @deprecated Please use StatusCodes.METHOD_FAILURE\n *\n * */\nexports.METHOD_FAILURE = 420;\n/**\n * @deprecated Please use StatusCodes.METHOD_NOT_ALLOWED\n *\n * */\nexports.METHOD_NOT_ALLOWED = 405;\n/**\n * @deprecated Please use StatusCodes.MOVED_PERMANENTLY\n *\n * */\nexports.MOVED_PERMANENTLY = 301;\n/**\n * @deprecated Please use StatusCodes.MOVED_TEMPORARILY\n *\n * */\nexports.MOVED_TEMPORARILY = 302;\n/**\n * @deprecated Please use StatusCodes.MULTI_STATUS\n *\n * */\nexports.MULTI_STATUS = 207;\n/**\n * @deprecated Please use StatusCodes.MULTIPLE_CHOICES\n *\n * */\nexports.MULTIPLE_CHOICES = 300;\n/**\n * @deprecated Please use StatusCodes.NETWORK_AUTHENTICATION_REQUIRED\n *\n * */\nexports.NETWORK_AUTHENTICATION_REQUIRED = 511;\n/**\n * @deprecated Please use StatusCodes.NO_CONTENT\n *\n * */\nexports.NO_CONTENT = 204;\n/**\n * @deprecated Please use StatusCodes.NON_AUTHORITATIVE_INFORMATION\n *\n * */\nexports.NON_AUTHORITATIVE_INFORMATION = 203;\n/**\n * @deprecated Please use StatusCodes.NOT_ACCEPTABLE\n *\n * */\nexports.NOT_ACCEPTABLE = 406;\n/**\n * @deprecated Please use StatusCodes.NOT_FOUND\n *\n * */\nexports.NOT_FOUND = 404;\n/**\n * @deprecated Please use StatusCodes.NOT_IMPLEMENTED\n *\n * */\nexports.NOT_IMPLEMENTED = 501;\n/**\n * @deprecated Please use StatusCodes.NOT_MODIFIED\n *\n * */\nexports.NOT_MODIFIED = 304;\n/**\n * @deprecated Please use StatusCodes.OK\n *\n * */\nexports.OK = 200;\n/**\n * @deprecated Please use StatusCodes.PARTIAL_CONTENT\n *\n * */\nexports.PARTIAL_CONTENT = 206;\n/**\n * @deprecated Please use StatusCodes.PAYMENT_REQUIRED\n *\n * */\nexports.PAYMENT_REQUIRED = 402;\n/**\n * @deprecated Please use StatusCodes.PERMANENT_REDIRECT\n *\n * */\nexports.PERMANENT_REDIRECT = 308;\n/**\n * @deprecated Please use StatusCodes.PRECONDITION_FAILED\n *\n * */\nexports.PRECONDITION_FAILED = 412;\n/**\n * @deprecated Please use StatusCodes.PRECONDITION_REQUIRED\n *\n * */\nexports.PRECONDITION_REQUIRED = 428;\n/**\n * @deprecated Please use StatusCodes.PROCESSING\n *\n * */\nexports.PROCESSING = 102;\n/**\n * @deprecated Please use StatusCodes.PROXY_AUTHENTICATION_REQUIRED\n *\n * */\nexports.PROXY_AUTHENTICATION_REQUIRED = 407;\n/**\n * @deprecated Please use StatusCodes.REQUEST_HEADER_FIELDS_TOO_LARGE\n *\n * */\nexports.REQUEST_HEADER_FIELDS_TOO_LARGE = 431;\n/**\n * @deprecated Please use StatusCodes.REQUEST_TIMEOUT\n *\n * */\nexports.REQUEST_TIMEOUT = 408;\n/**\n * @deprecated Please use StatusCodes.REQUEST_TOO_LONG\n *\n * */\nexports.REQUEST_TOO_LONG = 413;\n/**\n * @deprecated Please use StatusCodes.REQUEST_URI_TOO_LONG\n *\n * */\nexports.REQUEST_URI_TOO_LONG = 414;\n/**\n * @deprecated Please use StatusCodes.REQUESTED_RANGE_NOT_SATISFIABLE\n *\n * */\nexports.REQUESTED_RANGE_NOT_SATISFIABLE = 416;\n/**\n * @deprecated Please use StatusCodes.RESET_CONTENT\n *\n * */\nexports.RESET_CONTENT = 205;\n/**\n * @deprecated Please use StatusCodes.SEE_OTHER\n *\n * */\nexports.SEE_OTHER = 303;\n/**\n * @deprecated Please use StatusCodes.SERVICE_UNAVAILABLE\n *\n * */\nexports.SERVICE_UNAVAILABLE = 503;\n/**\n * @deprecated Please use StatusCodes.SWITCHING_PROTOCOLS\n *\n * */\nexports.SWITCHING_PROTOCOLS = 101;\n/**\n * @deprecated Please use StatusCodes.TEMPORARY_REDIRECT\n *\n * */\nexports.TEMPORARY_REDIRECT = 307;\n/**\n * @deprecated Please use StatusCodes.TOO_MANY_REQUESTS\n *\n * */\nexports.TOO_MANY_REQUESTS = 429;\n/**\n * @deprecated Please use StatusCodes.UNAUTHORIZED\n *\n * */\nexports.UNAUTHORIZED = 401;\n/**\n * @deprecated Please use StatusCodes.UNPROCESSABLE_ENTITY\n *\n * */\nexports.UNPROCESSABLE_ENTITY = 422;\n/**\n * @deprecated Please use StatusCodes.UNSUPPORTED_MEDIA_TYPE\n *\n * */\nexports.UNSUPPORTED_MEDIA_TYPE = 415;\n/**\n * @deprecated Please use StatusCodes.USE_PROXY\n *\n * */\nexports.USE_PROXY = 305;\nexports.default = {\n    ACCEPTED: exports.ACCEPTED,\n    BAD_GATEWAY: exports.BAD_GATEWAY,\n    BAD_REQUEST: exports.BAD_REQUEST,\n    CONFLICT: exports.CONFLICT,\n    CONTINUE: exports.CONTINUE,\n    CREATED: exports.CREATED,\n    EXPECTATION_FAILED: exports.EXPECTATION_FAILED,\n    FORBIDDEN: exports.FORBIDDEN,\n    GATEWAY_TIMEOUT: exports.GATEWAY_TIMEOUT,\n    GONE: exports.GONE,\n    HTTP_VERSION_NOT_SUPPORTED: exports.HTTP_VERSION_NOT_SUPPORTED,\n    IM_A_TEAPOT: exports.IM_A_TEAPOT,\n    INSUFFICIENT_SPACE_ON_RESOURCE: exports.INSUFFICIENT_SPACE_ON_RESOURCE,\n    INSUFFICIENT_STORAGE: exports.INSUFFICIENT_STORAGE,\n    INTERNAL_SERVER_ERROR: exports.INTERNAL_SERVER_ERROR,\n    LENGTH_REQUIRED: exports.LENGTH_REQUIRED,\n    LOCKED: exports.LOCKED,\n    METHOD_FAILURE: exports.METHOD_FAILURE,\n    METHOD_NOT_ALLOWED: exports.METHOD_NOT_ALLOWED,\n    MOVED_PERMANENTLY: exports.MOVED_PERMANENTLY,\n    MOVED_TEMPORARILY: exports.MOVED_TEMPORARILY,\n    MULTI_STATUS: exports.MULTI_STATUS,\n    MULTIPLE_CHOICES: exports.MULTIPLE_CHOICES,\n    NETWORK_AUTHENTICATION_REQUIRED: exports.NETWORK_AUTHENTICATION_REQUIRED,\n    NO_CONTENT: exports.NO_CONTENT,\n    NON_AUTHORITATIVE_INFORMATION: exports.NON_AUTHORITATIVE_INFORMATION,\n    NOT_ACCEPTABLE: exports.NOT_ACCEPTABLE,\n    NOT_FOUND: exports.NOT_FOUND,\n    NOT_IMPLEMENTED: exports.NOT_IMPLEMENTED,\n    NOT_MODIFIED: exports.NOT_MODIFIED,\n    OK: exports.OK,\n    PARTIAL_CONTENT: exports.PARTIAL_CONTENT,\n    PAYMENT_REQUIRED: exports.PAYMENT_REQUIRED,\n    PERMANENT_REDIRECT: exports.PERMANENT_REDIRECT,\n    PRECONDITION_FAILED: exports.PRECONDITION_FAILED,\n    PRECONDITION_REQUIRED: exports.PRECONDITION_REQUIRED,\n    PROCESSING: exports.PROCESSING,\n    PROXY_AUTHENTICATION_REQUIRED: exports.PROXY_AUTHENTICATION_REQUIRED,\n    REQUEST_HEADER_FIELDS_TOO_LARGE: exports.REQUEST_HEADER_FIELDS_TOO_LARGE,\n    REQUEST_TIMEOUT: exports.REQUEST_TIMEOUT,\n    REQUEST_TOO_LONG: exports.REQUEST_TOO_LONG,\n    REQUEST_URI_TOO_LONG: exports.REQUEST_URI_TOO_LONG,\n    REQUESTED_RANGE_NOT_SATISFIABLE: exports.REQUESTED_RANGE_NOT_SATISFIABLE,\n    RESET_CONTENT: exports.RESET_CONTENT,\n    SEE_OTHER: exports.SEE_OTHER,\n    SERVICE_UNAVAILABLE: exports.SERVICE_UNAVAILABLE,\n    SWITCHING_PROTOCOLS: exports.SWITCHING_PROTOCOLS,\n    TEMPORARY_REDIRECT: exports.TEMPORARY_REDIRECT,\n    TOO_MANY_REQUESTS: exports.TOO_MANY_REQUESTS,\n    UNAUTHORIZED: exports.UNAUTHORIZED,\n    UNPROCESSABLE_ENTITY: exports.UNPROCESSABLE_ENTITY,\n    UNSUPPORTED_MEDIA_TYPE: exports.UNSUPPORTED_MEDIA_TYPE,\n    USE_PROXY: exports.USE_PROXY,\n};\n", "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.reasonPhraseToStatusCode = exports.statusCodeToReasonPhrase = void 0;\n// Generated file. Do not edit\nexports.statusCodeToReasonPhrase = {\n    \"202\": \"Accepted\",\n    \"502\": \"Bad Gateway\",\n    \"400\": \"Bad Request\",\n    \"409\": \"Conflict\",\n    \"100\": \"Continue\",\n    \"201\": \"Created\",\n    \"417\": \"Expectation Failed\",\n    \"424\": \"Failed Dependency\",\n    \"403\": \"Forbidden\",\n    \"504\": \"Gateway Timeout\",\n    \"410\": \"Gone\",\n    \"505\": \"HTTP Version Not Supported\",\n    \"418\": \"I'm a teapot\",\n    \"419\": \"Insufficient Space on Resource\",\n    \"507\": \"Insufficient Storage\",\n    \"500\": \"Internal Server Error\",\n    \"411\": \"Length Required\",\n    \"423\": \"Locked\",\n    \"420\": \"Method Failure\",\n    \"405\": \"Method Not Allowed\",\n    \"301\": \"Moved Permanently\",\n    \"302\": \"Moved Temporarily\",\n    \"207\": \"Multi-Status\",\n    \"300\": \"Multiple Choices\",\n    \"511\": \"Network Authentication Required\",\n    \"204\": \"No Content\",\n    \"203\": \"Non Authoritative Information\",\n    \"406\": \"Not Acceptable\",\n    \"404\": \"Not Found\",\n    \"501\": \"Not Implemented\",\n    \"304\": \"Not Modified\",\n    \"200\": \"OK\",\n    \"206\": \"Partial Content\",\n    \"402\": \"Payment Required\",\n    \"308\": \"Permanent Redirect\",\n    \"412\": \"Precondition Failed\",\n    \"428\": \"Precondition Required\",\n    \"102\": \"Processing\",\n    \"103\": \"Early Hints\",\n    \"426\": \"Upgrade Required\",\n    \"407\": \"Proxy Authentication Required\",\n    \"431\": \"Request Header Fields Too Large\",\n    \"408\": \"Request Timeout\",\n    \"413\": \"Request Entity Too Large\",\n    \"414\": \"Request-URI Too Long\",\n    \"416\": \"Requested Range Not Satisfiable\",\n    \"205\": \"Reset Content\",\n    \"303\": \"See Other\",\n    \"503\": \"Service Unavailable\",\n    \"101\": \"Switching Protocols\",\n    \"307\": \"Temporary Redirect\",\n    \"429\": \"Too Many Requests\",\n    \"401\": \"Unauthorized\",\n    \"451\": \"Unavailable For Legal Reasons\",\n    \"422\": \"Unprocessable Entity\",\n    \"415\": \"Unsupported Media Type\",\n    \"305\": \"Use Proxy\",\n    \"421\": \"Misdirected Request\"\n};\nexports.reasonPhraseToStatusCode = {\n    \"Accepted\": 202,\n    \"Bad Gateway\": 502,\n    \"Bad Request\": 400,\n    \"Conflict\": 409,\n    \"Continue\": 100,\n    \"Created\": 201,\n    \"Expectation Failed\": 417,\n    \"Failed Dependency\": 424,\n    \"Forbidden\": 403,\n    \"Gateway Timeout\": 504,\n    \"Gone\": 410,\n    \"HTTP Version Not Supported\": 505,\n    \"I'm a teapot\": 418,\n    \"Insufficient Space on Resource\": 419,\n    \"Insufficient Storage\": 507,\n    \"Internal Server Error\": 500,\n    \"Length Required\": 411,\n    \"Locked\": 423,\n    \"Method Failure\": 420,\n    \"Method Not Allowed\": 405,\n    \"Moved Permanently\": 301,\n    \"Moved Temporarily\": 302,\n    \"Multi-Status\": 207,\n    \"Multiple Choices\": 300,\n    \"Network Authentication Required\": 511,\n    \"No Content\": 204,\n    \"Non Authoritative Information\": 203,\n    \"Not Acceptable\": 406,\n    \"Not Found\": 404,\n    \"Not Implemented\": 501,\n    \"Not Modified\": 304,\n    \"OK\": 200,\n    \"Partial Content\": 206,\n    \"Payment Required\": 402,\n    \"Permanent Redirect\": 308,\n    \"Precondition Failed\": 412,\n    \"Precondition Required\": 428,\n    \"Processing\": 102,\n    \"Early Hints\": 103,\n    \"Upgrade Required\": 426,\n    \"Proxy Authentication Required\": 407,\n    \"Request Header Fields Too Large\": 431,\n    \"Request Timeout\": 408,\n    \"Request Entity Too Large\": 413,\n    \"Request-URI Too Long\": 414,\n    \"Requested Range Not Satisfiable\": 416,\n    \"Reset Content\": 205,\n    \"See Other\": 303,\n    \"Service Unavailable\": 503,\n    \"Switching Protocols\": 101,\n    \"Temporary Redirect\": 307,\n    \"Too Many Requests\": 429,\n    \"Unauthorized\": 401,\n    \"Unavailable For Legal Reasons\": 451,\n    \"Unprocessable Entity\": 422,\n    \"Unsupported Media Type\": 415,\n    \"Use Proxy\": 305,\n    \"Misdirected Request\": 421\n};\n", "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getStatusText = exports.getStatusCode = exports.getReasonPhrase = void 0;\nvar utils_1 = require(\"./utils\");\n/**\n * Returns the reason phrase for the given status code.\n * If the given status code does not exist, an error is thrown.\n *\n * @param {number|string} statusCode The HTTP status code\n * @returns {string} The associated reason phrase (e.g. \"Bad Request\", \"OK\")\n * */\nfunction getReasonPhrase(statusCode) {\n    var result = utils_1.statusCodeToReasonPhrase[statusCode.toString()];\n    if (!result) {\n        throw new Error(\"Status code does not exist: \" + statusCode);\n    }\n    return result;\n}\nexports.getReasonPhrase = getReasonPhrase;\n/**\n * Returns the status code for the given reason phrase.\n * If the given reason phrase does not exist, undefined is returned.\n *\n * @param {string} reasonPhrase The HTTP reason phrase (e.g. \"Bad Request\", \"OK\")\n * @returns {string} The associated status code\n * */\nfunction getStatusCode(reasonPhrase) {\n    var result = utils_1.reasonPhraseToStatusCode[reasonPhrase];\n    if (!result) {\n        throw new Error(\"Reason phrase does not exist: \" + reasonPhrase);\n    }\n    return result;\n}\nexports.getStatusCode = getStatusCode;\n/**\n * @deprecated\n *\n * Returns the reason phrase for the given status code.\n * If the given status code does not exist, undefined is returned.\n *\n * Deprecated in favor of getReasonPhrase\n *\n * @param {number|string} statusCode The HTTP status code\n * @returns {string|undefined} The associated reason phrase (e.g. \"Bad Request\", \"OK\")\n * */\nexports.getStatusText = getReasonPhrase;\n", "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.StatusCodes = void 0;\n// Generated file. Do not edit\nvar StatusCodes;\n(function (StatusCodes) {\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.2.1\n     *\n     * This interim response indicates that everything so far is OK and that the client should continue with the request or ignore it if it is already finished.\n     */\n    StatusCodes[StatusCodes[\"CONTINUE\"] = 100] = \"CONTINUE\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.2.2\n     *\n     * This code is sent in response to an Upgrade request header by the client, and indicates the protocol the server is switching too.\n     */\n    StatusCodes[StatusCodes[\"SWITCHING_PROTOCOLS\"] = 101] = \"SWITCHING_PROTOCOLS\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.1\n     *\n     * This code indicates that the server has received and is processing the request, but no response is available yet.\n     */\n    StatusCodes[StatusCodes[\"PROCESSING\"] = 102] = \"PROCESSING\";\n    /**\n     * Official Documentation @ https://www.rfc-editor.org/rfc/rfc8297#page-3\n     *\n     * This code indicates to the client that the server is likely to send a final response with the header fields included in the informational response.\n     */\n    StatusCodes[StatusCodes[\"EARLY_HINTS\"] = 103] = \"EARLY_HINTS\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.3.1\n     *\n     * The request has succeeded. The meaning of a success varies depending on the HTTP method:\n     * GET: The resource has been fetched and is transmitted in the message body.\n     * HEAD: The entity headers are in the message body.\n     * POST: The resource describing the result of the action is transmitted in the message body.\n     * TRACE: The message body contains the request message as received by the server\n     */\n    StatusCodes[StatusCodes[\"OK\"] = 200] = \"OK\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.3.2\n     *\n     * The request has succeeded and a new resource has been created as a result of it. This is typically the response sent after a PUT request.\n     */\n    StatusCodes[StatusCodes[\"CREATED\"] = 201] = \"CREATED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.3.3\n     *\n     * The request has been received but not yet acted upon. It is non-committal, meaning that there is no way in HTTP to later send an asynchronous response indicating the outcome of processing the request. It is intended for cases where another process or server handles the request, or for batch processing.\n     */\n    StatusCodes[StatusCodes[\"ACCEPTED\"] = 202] = \"ACCEPTED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.3.4\n     *\n     * This response code means returned meta-information set is not exact set as available from the origin server, but collected from a local or a third party copy. Except this condition, 200 OK response should be preferred instead of this response.\n     */\n    StatusCodes[StatusCodes[\"NON_AUTHORITATIVE_INFORMATION\"] = 203] = \"NON_AUTHORITATIVE_INFORMATION\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.3.5\n     *\n     * There is no content to send for this request, but the headers may be useful. The user-agent may update its cached headers for this resource with the new ones.\n     */\n    StatusCodes[StatusCodes[\"NO_CONTENT\"] = 204] = \"NO_CONTENT\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.3.6\n     *\n     * This response code is sent after accomplishing request to tell user agent reset document view which sent this request.\n     */\n    StatusCodes[StatusCodes[\"RESET_CONTENT\"] = 205] = \"RESET_CONTENT\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7233#section-4.1\n     *\n     * This response code is used because of range header sent by the client to separate download into multiple streams.\n     */\n    StatusCodes[StatusCodes[\"PARTIAL_CONTENT\"] = 206] = \"PARTIAL_CONTENT\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.2\n     *\n     * A Multi-Status response conveys information about multiple resources in situations where multiple status codes might be appropriate.\n     */\n    StatusCodes[StatusCodes[\"MULTI_STATUS\"] = 207] = \"MULTI_STATUS\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.4.1\n     *\n     * The request has more than one possible responses. User-agent or user should choose one of them. There is no standardized way to choose one of the responses.\n     */\n    StatusCodes[StatusCodes[\"MULTIPLE_CHOICES\"] = 300] = \"MULTIPLE_CHOICES\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.4.2\n     *\n     * This response code means that URI of requested resource has been changed. Probably, new URI would be given in the response.\n     */\n    StatusCodes[StatusCodes[\"MOVED_PERMANENTLY\"] = 301] = \"MOVED_PERMANENTLY\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.4.3\n     *\n     * This response code means that URI of requested resource has been changed temporarily. New changes in the URI might be made in the future. Therefore, this same URI should be used by the client in future requests.\n     */\n    StatusCodes[StatusCodes[\"MOVED_TEMPORARILY\"] = 302] = \"MOVED_TEMPORARILY\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.4.4\n     *\n     * Server sent this response to directing client to get requested resource to another URI with an GET request.\n     */\n    StatusCodes[StatusCodes[\"SEE_OTHER\"] = 303] = \"SEE_OTHER\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7232#section-4.1\n     *\n     * This is used for caching purposes. It is telling to client that response has not been modified. So, client can continue to use same cached version of response.\n     */\n    StatusCodes[StatusCodes[\"NOT_MODIFIED\"] = 304] = \"NOT_MODIFIED\";\n    /**\n     * @deprecated\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.4.6\n     *\n     * Was defined in a previous version of the HTTP specification to indicate that a requested response must be accessed by a proxy. It has been deprecated due to security concerns regarding in-band configuration of a proxy.\n     */\n    StatusCodes[StatusCodes[\"USE_PROXY\"] = 305] = \"USE_PROXY\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.4.7\n     *\n     * Server sent this response to directing client to get requested resource to another URI with same method that used prior request. This has the same semantic than the 302 Found HTTP response code, with the exception that the user agent must not change the HTTP method used: if a POST was used in the first request, a POST must be used in the second request.\n     */\n    StatusCodes[StatusCodes[\"TEMPORARY_REDIRECT\"] = 307] = \"TEMPORARY_REDIRECT\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7538#section-3\n     *\n     * This means that the resource is now permanently located at another URI, specified by the Location: HTTP Response header. This has the same semantics as the 301 Moved Permanently HTTP response code, with the exception that the user agent must not change the HTTP method used: if a POST was used in the first request, a POST must be used in the second request.\n     */\n    StatusCodes[StatusCodes[\"PERMANENT_REDIRECT\"] = 308] = \"PERMANENT_REDIRECT\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.1\n     *\n     * This response means that server could not understand the request due to invalid syntax.\n     */\n    StatusCodes[StatusCodes[\"BAD_REQUEST\"] = 400] = \"BAD_REQUEST\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7235#section-3.1\n     *\n     * Although the HTTP standard specifies \"unauthorized\", semantically this response means \"unauthenticated\". That is, the client must authenticate itself to get the requested response.\n     */\n    StatusCodes[StatusCodes[\"UNAUTHORIZED\"] = 401] = \"UNAUTHORIZED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.2\n     *\n     * This response code is reserved for future use. Initial aim for creating this code was using it for digital payment systems however this is not used currently.\n     */\n    StatusCodes[StatusCodes[\"PAYMENT_REQUIRED\"] = 402] = \"PAYMENT_REQUIRED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.3\n     *\n     * The client does not have access rights to the content, i.e. they are unauthorized, so server is rejecting to give proper response. Unlike 401, the client's identity is known to the server.\n     */\n    StatusCodes[StatusCodes[\"FORBIDDEN\"] = 403] = \"FORBIDDEN\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.4\n     *\n     * The server can not find requested resource. In the browser, this means the URL is not recognized. In an API, this can also mean that the endpoint is valid but the resource itself does not exist. Servers may also send this response instead of 403 to hide the existence of a resource from an unauthorized client. This response code is probably the most famous one due to its frequent occurence on the web.\n     */\n    StatusCodes[StatusCodes[\"NOT_FOUND\"] = 404] = \"NOT_FOUND\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.5\n     *\n     * The request method is known by the server but has been disabled and cannot be used. For example, an API may forbid DELETE-ing a resource. The two mandatory methods, GET and HEAD, must never be disabled and should not return this error code.\n     */\n    StatusCodes[StatusCodes[\"METHOD_NOT_ALLOWED\"] = 405] = \"METHOD_NOT_ALLOWED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.6\n     *\n     * This response is sent when the web server, after performing server-driven content negotiation, doesn't find any content following the criteria given by the user agent.\n     */\n    StatusCodes[StatusCodes[\"NOT_ACCEPTABLE\"] = 406] = \"NOT_ACCEPTABLE\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7235#section-3.2\n     *\n     * This is similar to 401 but authentication is needed to be done by a proxy.\n     */\n    StatusCodes[StatusCodes[\"PROXY_AUTHENTICATION_REQUIRED\"] = 407] = \"PROXY_AUTHENTICATION_REQUIRED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.7\n     *\n     * This response is sent on an idle connection by some servers, even without any previous request by the client. It means that the server would like to shut down this unused connection. This response is used much more since some browsers, like Chrome, Firefox 27+, or IE9, use HTTP pre-connection mechanisms to speed up surfing. Also note that some servers merely shut down the connection without sending this message.\n     */\n    StatusCodes[StatusCodes[\"REQUEST_TIMEOUT\"] = 408] = \"REQUEST_TIMEOUT\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.8\n     *\n     * This response is sent when a request conflicts with the current state of the server.\n     */\n    StatusCodes[StatusCodes[\"CONFLICT\"] = 409] = \"CONFLICT\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.9\n     *\n     * This response would be sent when the requested content has been permenantly deleted from server, with no forwarding address. Clients are expected to remove their caches and links to the resource. The HTTP specification intends this status code to be used for \"limited-time, promotional services\". APIs should not feel compelled to indicate resources that have been deleted with this status code.\n     */\n    StatusCodes[StatusCodes[\"GONE\"] = 410] = \"GONE\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.10\n     *\n     * The server rejected the request because the Content-Length header field is not defined and the server requires it.\n     */\n    StatusCodes[StatusCodes[\"LENGTH_REQUIRED\"] = 411] = \"LENGTH_REQUIRED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7232#section-4.2\n     *\n     * The client has indicated preconditions in its headers which the server does not meet.\n     */\n    StatusCodes[StatusCodes[\"PRECONDITION_FAILED\"] = 412] = \"PRECONDITION_FAILED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.11\n     *\n     * Request entity is larger than limits defined by server; the server might close the connection or return an Retry-After header field.\n     */\n    StatusCodes[StatusCodes[\"REQUEST_TOO_LONG\"] = 413] = \"REQUEST_TOO_LONG\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.12\n     *\n     * The URI requested by the client is longer than the server is willing to interpret.\n     */\n    StatusCodes[StatusCodes[\"REQUEST_URI_TOO_LONG\"] = 414] = \"REQUEST_URI_TOO_LONG\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.13\n     *\n     * The media format of the requested data is not supported by the server, so the server is rejecting the request.\n     */\n    StatusCodes[StatusCodes[\"UNSUPPORTED_MEDIA_TYPE\"] = 415] = \"UNSUPPORTED_MEDIA_TYPE\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7233#section-4.4\n     *\n     * The range specified by the Range header field in the request can't be fulfilled; it's possible that the range is outside the size of the target URI's data.\n     */\n    StatusCodes[StatusCodes[\"REQUESTED_RANGE_NOT_SATISFIABLE\"] = 416] = \"REQUESTED_RANGE_NOT_SATISFIABLE\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.14\n     *\n     * This response code means the expectation indicated by the Expect request header field can't be met by the server.\n     */\n    StatusCodes[StatusCodes[\"EXPECTATION_FAILED\"] = 417] = \"EXPECTATION_FAILED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2324#section-2.3.2\n     *\n     * Any attempt to brew coffee with a teapot should result in the error code \"418 I'm a teapot\". The resulting entity body MAY be short and stout.\n     */\n    StatusCodes[StatusCodes[\"IM_A_TEAPOT\"] = 418] = \"IM_A_TEAPOT\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.6\n     *\n     * The 507 (Insufficient Storage) status code means the method could not be performed on the resource because the server is unable to store the representation needed to successfully complete the request. This condition is considered to be temporary. If the request which received this status code was the result of a user action, the request MUST NOT be repeated until it is requested by a separate user action.\n     */\n    StatusCodes[StatusCodes[\"INSUFFICIENT_SPACE_ON_RESOURCE\"] = 419] = \"INSUFFICIENT_SPACE_ON_RESOURCE\";\n    /**\n     * @deprecated\n     * Official Documentation @ https://tools.ietf.org/rfcdiff?difftype=--hwdiff&url2=draft-ietf-webdav-protocol-06.txt\n     *\n     * A deprecated response used by the Spring Framework when a method has failed.\n     */\n    StatusCodes[StatusCodes[\"METHOD_FAILURE\"] = 420] = \"METHOD_FAILURE\";\n    /**\n     * Official Documentation @ https://datatracker.ietf.org/doc/html/rfc7540#section-9.1.2\n     *\n     * Defined in the specification of HTTP/2 to indicate that a server is not able to produce a response for the combination of scheme and authority that are included in the request URI.\n     */\n    StatusCodes[StatusCodes[\"MISDIRECTED_REQUEST\"] = 421] = \"MISDIRECTED_REQUEST\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.3\n     *\n     * The request was well-formed but was unable to be followed due to semantic errors.\n     */\n    StatusCodes[StatusCodes[\"UNPROCESSABLE_ENTITY\"] = 422] = \"UNPROCESSABLE_ENTITY\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.4\n     *\n     * The resource that is being accessed is locked.\n     */\n    StatusCodes[StatusCodes[\"LOCKED\"] = 423] = \"LOCKED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.5\n     *\n     * The request failed due to failure of a previous request.\n     */\n    StatusCodes[StatusCodes[\"FAILED_DEPENDENCY\"] = 424] = \"FAILED_DEPENDENCY\";\n    /**\n     * Official Documentation @ https://datatracker.ietf.org/doc/html/rfc7231#section-6.5.15\n     *\n     * The server refuses to perform the request using the current protocol but might be willing to do so after the client upgrades to a different protocol.\n     */\n    StatusCodes[StatusCodes[\"UPGRADE_REQUIRED\"] = 426] = \"UPGRADE_REQUIRED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc6585#section-3\n     *\n     * The origin server requires the request to be conditional. Intended to prevent the 'lost update' problem, where a client GETs a resource's state, modifies it, and PUTs it back to the server, when meanwhile a third party has modified the state on the server, leading to a conflict.\n     */\n    StatusCodes[StatusCodes[\"PRECONDITION_REQUIRED\"] = 428] = \"PRECONDITION_REQUIRED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc6585#section-4\n     *\n     * The user has sent too many requests in a given amount of time (\"rate limiting\").\n     */\n    StatusCodes[StatusCodes[\"TOO_MANY_REQUESTS\"] = 429] = \"TOO_MANY_REQUESTS\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc6585#section-5\n     *\n     * The server is unwilling to process the request because its header fields are too large. The request MAY be resubmitted after reducing the size of the request header fields.\n     */\n    StatusCodes[StatusCodes[\"REQUEST_HEADER_FIELDS_TOO_LARGE\"] = 431] = \"REQUEST_HEADER_FIELDS_TOO_LARGE\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7725\n     *\n     * The user-agent requested a resource that cannot legally be provided, such as a web page censored by a government.\n     */\n    StatusCodes[StatusCodes[\"UNAVAILABLE_FOR_LEGAL_REASONS\"] = 451] = \"UNAVAILABLE_FOR_LEGAL_REASONS\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.6.1\n     *\n     * The server encountered an unexpected condition that prevented it from fulfilling the request.\n     */\n    StatusCodes[StatusCodes[\"INTERNAL_SERVER_ERROR\"] = 500] = \"INTERNAL_SERVER_ERROR\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.6.2\n     *\n     * The request method is not supported by the server and cannot be handled. The only methods that servers are required to support (and therefore that must not return this code) are GET and HEAD.\n     */\n    StatusCodes[StatusCodes[\"NOT_IMPLEMENTED\"] = 501] = \"NOT_IMPLEMENTED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.6.3\n     *\n     * This error response means that the server, while working as a gateway to get a response needed to handle the request, got an invalid response.\n     */\n    StatusCodes[StatusCodes[\"BAD_GATEWAY\"] = 502] = \"BAD_GATEWAY\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.6.4\n     *\n     * The server is not ready to handle the request. Common causes are a server that is down for maintenance or that is overloaded. Note that together with this response, a user-friendly page explaining the problem should be sent. This responses should be used for temporary conditions and the Retry-After: HTTP header should, if possible, contain the estimated time before the recovery of the service. The webmaster must also take care about the caching-related headers that are sent along with this response, as these temporary condition responses should usually not be cached.\n     */\n    StatusCodes[StatusCodes[\"SERVICE_UNAVAILABLE\"] = 503] = \"SERVICE_UNAVAILABLE\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.6.5\n     *\n     * This error response is given when the server is acting as a gateway and cannot get a response in time.\n     */\n    StatusCodes[StatusCodes[\"GATEWAY_TIMEOUT\"] = 504] = \"GATEWAY_TIMEOUT\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.6.6\n     *\n     * The HTTP version used in the request is not supported by the server.\n     */\n    StatusCodes[StatusCodes[\"HTTP_VERSION_NOT_SUPPORTED\"] = 505] = \"HTTP_VERSION_NOT_SUPPORTED\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.6\n     *\n     * The server has an internal configuration error: the chosen variant resource is configured to engage in transparent content negotiation itself, and is therefore not a proper end point in the negotiation process.\n     */\n    StatusCodes[StatusCodes[\"INSUFFICIENT_STORAGE\"] = 507] = \"INSUFFICIENT_STORAGE\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc6585#section-6\n     *\n     * The 511 status code indicates that the client needs to authenticate to gain network access.\n     */\n    StatusCodes[StatusCodes[\"NETWORK_AUTHENTICATION_REQUIRED\"] = 511] = \"NETWORK_AUTHENTICATION_REQUIRED\";\n})(StatusCodes = exports.StatusCodes || (exports.StatusCodes = {}));\n", "\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ReasonPhrases = void 0;\n// Generated file. Do not edit\nvar ReasonPhrases;\n(function (ReasonPhrases) {\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.3.3\n     *\n     * The request has been received but not yet acted upon. It is non-committal, meaning that there is no way in HTTP to later send an asynchronous response indicating the outcome of processing the request. It is intended for cases where another process or server handles the request, or for batch processing.\n     */\n    ReasonPhrases[\"ACCEPTED\"] = \"Accepted\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.6.3\n     *\n     * This error response means that the server, while working as a gateway to get a response needed to handle the request, got an invalid response.\n     */\n    ReasonPhrases[\"BAD_GATEWAY\"] = \"Bad Gateway\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.1\n     *\n     * This response means that server could not understand the request due to invalid syntax.\n     */\n    ReasonPhrases[\"BAD_REQUEST\"] = \"Bad Request\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.8\n     *\n     * This response is sent when a request conflicts with the current state of the server.\n     */\n    ReasonPhrases[\"CONFLICT\"] = \"Conflict\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.2.1\n     *\n     * This interim response indicates that everything so far is OK and that the client should continue with the request or ignore it if it is already finished.\n     */\n    ReasonPhrases[\"CONTINUE\"] = \"Continue\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.3.2\n     *\n     * The request has succeeded and a new resource has been created as a result of it. This is typically the response sent after a PUT request.\n     */\n    ReasonPhrases[\"CREATED\"] = \"Created\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.14\n     *\n     * This response code means the expectation indicated by the Expect request header field can't be met by the server.\n     */\n    ReasonPhrases[\"EXPECTATION_FAILED\"] = \"Expectation Failed\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.5\n     *\n     * The request failed due to failure of a previous request.\n     */\n    ReasonPhrases[\"FAILED_DEPENDENCY\"] = \"Failed Dependency\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.3\n     *\n     * The client does not have access rights to the content, i.e. they are unauthorized, so server is rejecting to give proper response. Unlike 401, the client's identity is known to the server.\n     */\n    ReasonPhrases[\"FORBIDDEN\"] = \"Forbidden\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.6.5\n     *\n     * This error response is given when the server is acting as a gateway and cannot get a response in time.\n     */\n    ReasonPhrases[\"GATEWAY_TIMEOUT\"] = \"Gateway Timeout\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.9\n     *\n     * This response would be sent when the requested content has been permenantly deleted from server, with no forwarding address. Clients are expected to remove their caches and links to the resource. The HTTP specification intends this status code to be used for \"limited-time, promotional services\". APIs should not feel compelled to indicate resources that have been deleted with this status code.\n     */\n    ReasonPhrases[\"GONE\"] = \"Gone\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.6.6\n     *\n     * The HTTP version used in the request is not supported by the server.\n     */\n    ReasonPhrases[\"HTTP_VERSION_NOT_SUPPORTED\"] = \"HTTP Version Not Supported\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2324#section-2.3.2\n     *\n     * Any attempt to brew coffee with a teapot should result in the error code \"418 I'm a teapot\". The resulting entity body MAY be short and stout.\n     */\n    ReasonPhrases[\"IM_A_TEAPOT\"] = \"I'm a teapot\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.6\n     *\n     * The 507 (Insufficient Storage) status code means the method could not be performed on the resource because the server is unable to store the representation needed to successfully complete the request. This condition is considered to be temporary. If the request which received this status code was the result of a user action, the request MUST NOT be repeated until it is requested by a separate user action.\n     */\n    ReasonPhrases[\"INSUFFICIENT_SPACE_ON_RESOURCE\"] = \"Insufficient Space on Resource\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.6\n     *\n     * The server has an internal configuration error: the chosen variant resource is configured to engage in transparent content negotiation itself, and is therefore not a proper end point in the negotiation process.\n     */\n    ReasonPhrases[\"INSUFFICIENT_STORAGE\"] = \"Insufficient Storage\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.6.1\n     *\n     * The server encountered an unexpected condition that prevented it from fulfilling the request.\n     */\n    ReasonPhrases[\"INTERNAL_SERVER_ERROR\"] = \"Internal Server Error\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.10\n     *\n     * The server rejected the request because the Content-Length header field is not defined and the server requires it.\n     */\n    ReasonPhrases[\"LENGTH_REQUIRED\"] = \"Length Required\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.4\n     *\n     * The resource that is being accessed is locked.\n     */\n    ReasonPhrases[\"LOCKED\"] = \"Locked\";\n    /**\n     * @deprecated\n     * Official Documentation @ https://tools.ietf.org/rfcdiff?difftype=--hwdiff&url2=draft-ietf-webdav-protocol-06.txt\n     *\n     * A deprecated response used by the Spring Framework when a method has failed.\n     */\n    ReasonPhrases[\"METHOD_FAILURE\"] = \"Method Failure\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.5\n     *\n     * The request method is known by the server but has been disabled and cannot be used. For example, an API may forbid DELETE-ing a resource. The two mandatory methods, GET and HEAD, must never be disabled and should not return this error code.\n     */\n    ReasonPhrases[\"METHOD_NOT_ALLOWED\"] = \"Method Not Allowed\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.4.2\n     *\n     * This response code means that URI of requested resource has been changed. Probably, new URI would be given in the response.\n     */\n    ReasonPhrases[\"MOVED_PERMANENTLY\"] = \"Moved Permanently\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.4.3\n     *\n     * This response code means that URI of requested resource has been changed temporarily. New changes in the URI might be made in the future. Therefore, this same URI should be used by the client in future requests.\n     */\n    ReasonPhrases[\"MOVED_TEMPORARILY\"] = \"Moved Temporarily\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.2\n     *\n     * A Multi-Status response conveys information about multiple resources in situations where multiple status codes might be appropriate.\n     */\n    ReasonPhrases[\"MULTI_STATUS\"] = \"Multi-Status\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.4.1\n     *\n     * The request has more than one possible responses. User-agent or user should choose one of them. There is no standardized way to choose one of the responses.\n     */\n    ReasonPhrases[\"MULTIPLE_CHOICES\"] = \"Multiple Choices\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc6585#section-6\n     *\n     * The 511 status code indicates that the client needs to authenticate to gain network access.\n     */\n    ReasonPhrases[\"NETWORK_AUTHENTICATION_REQUIRED\"] = \"Network Authentication Required\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.3.5\n     *\n     * There is no content to send for this request, but the headers may be useful. The user-agent may update its cached headers for this resource with the new ones.\n     */\n    ReasonPhrases[\"NO_CONTENT\"] = \"No Content\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.3.4\n     *\n     * This response code means returned meta-information set is not exact set as available from the origin server, but collected from a local or a third party copy. Except this condition, 200 OK response should be preferred instead of this response.\n     */\n    ReasonPhrases[\"NON_AUTHORITATIVE_INFORMATION\"] = \"Non Authoritative Information\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.6\n     *\n     * This response is sent when the web server, after performing server-driven content negotiation, doesn't find any content following the criteria given by the user agent.\n     */\n    ReasonPhrases[\"NOT_ACCEPTABLE\"] = \"Not Acceptable\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.4\n     *\n     * The server can not find requested resource. In the browser, this means the URL is not recognized. In an API, this can also mean that the endpoint is valid but the resource itself does not exist. Servers may also send this response instead of 403 to hide the existence of a resource from an unauthorized client. This response code is probably the most famous one due to its frequent occurence on the web.\n     */\n    ReasonPhrases[\"NOT_FOUND\"] = \"Not Found\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.6.2\n     *\n     * The request method is not supported by the server and cannot be handled. The only methods that servers are required to support (and therefore that must not return this code) are GET and HEAD.\n     */\n    ReasonPhrases[\"NOT_IMPLEMENTED\"] = \"Not Implemented\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7232#section-4.1\n     *\n     * This is used for caching purposes. It is telling to client that response has not been modified. So, client can continue to use same cached version of response.\n     */\n    ReasonPhrases[\"NOT_MODIFIED\"] = \"Not Modified\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.3.1\n     *\n     * The request has succeeded. The meaning of a success varies depending on the HTTP method:\n     * GET: The resource has been fetched and is transmitted in the message body.\n     * HEAD: The entity headers are in the message body.\n     * POST: The resource describing the result of the action is transmitted in the message body.\n     * TRACE: The message body contains the request message as received by the server\n     */\n    ReasonPhrases[\"OK\"] = \"OK\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7233#section-4.1\n     *\n     * This response code is used because of range header sent by the client to separate download into multiple streams.\n     */\n    ReasonPhrases[\"PARTIAL_CONTENT\"] = \"Partial Content\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.2\n     *\n     * This response code is reserved for future use. Initial aim for creating this code was using it for digital payment systems however this is not used currently.\n     */\n    ReasonPhrases[\"PAYMENT_REQUIRED\"] = \"Payment Required\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7538#section-3\n     *\n     * This means that the resource is now permanently located at another URI, specified by the Location: HTTP Response header. This has the same semantics as the 301 Moved Permanently HTTP response code, with the exception that the user agent must not change the HTTP method used: if a POST was used in the first request, a POST must be used in the second request.\n     */\n    ReasonPhrases[\"PERMANENT_REDIRECT\"] = \"Permanent Redirect\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7232#section-4.2\n     *\n     * The client has indicated preconditions in its headers which the server does not meet.\n     */\n    ReasonPhrases[\"PRECONDITION_FAILED\"] = \"Precondition Failed\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc6585#section-3\n     *\n     * The origin server requires the request to be conditional. Intended to prevent the 'lost update' problem, where a client GETs a resource's state, modifies it, and PUTs it back to the server, when meanwhile a third party has modified the state on the server, leading to a conflict.\n     */\n    ReasonPhrases[\"PRECONDITION_REQUIRED\"] = \"Precondition Required\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.1\n     *\n     * This code indicates that the server has received and is processing the request, but no response is available yet.\n     */\n    ReasonPhrases[\"PROCESSING\"] = \"Processing\";\n    /**\n     * Official Documentation @ https://www.rfc-editor.org/rfc/rfc8297#page-3\n     *\n     * This code indicates to the client that the server is likely to send a final response with the header fields included in the informational response.\n     */\n    ReasonPhrases[\"EARLY_HINTS\"] = \"Early Hints\";\n    /**\n     * Official Documentation @ https://datatracker.ietf.org/doc/html/rfc7231#section-6.5.15\n     *\n     * The server refuses to perform the request using the current protocol but might be willing to do so after the client upgrades to a different protocol.\n     */\n    ReasonPhrases[\"UPGRADE_REQUIRED\"] = \"Upgrade Required\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7235#section-3.2\n     *\n     * This is similar to 401 but authentication is needed to be done by a proxy.\n     */\n    ReasonPhrases[\"PROXY_AUTHENTICATION_REQUIRED\"] = \"Proxy Authentication Required\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc6585#section-5\n     *\n     * The server is unwilling to process the request because its header fields are too large. The request MAY be resubmitted after reducing the size of the request header fields.\n     */\n    ReasonPhrases[\"REQUEST_HEADER_FIELDS_TOO_LARGE\"] = \"Request Header Fields Too Large\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.7\n     *\n     * This response is sent on an idle connection by some servers, even without any previous request by the client. It means that the server would like to shut down this unused connection. This response is used much more since some browsers, like Chrome, Firefox 27+, or IE9, use HTTP pre-connection mechanisms to speed up surfing. Also note that some servers merely shut down the connection without sending this message.\n     */\n    ReasonPhrases[\"REQUEST_TIMEOUT\"] = \"Request Timeout\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.11\n     *\n     * Request entity is larger than limits defined by server; the server might close the connection or return an Retry-After header field.\n     */\n    ReasonPhrases[\"REQUEST_TOO_LONG\"] = \"Request Entity Too Large\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.12\n     *\n     * The URI requested by the client is longer than the server is willing to interpret.\n     */\n    ReasonPhrases[\"REQUEST_URI_TOO_LONG\"] = \"Request-URI Too Long\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7233#section-4.4\n     *\n     * The range specified by the Range header field in the request can't be fulfilled; it's possible that the range is outside the size of the target URI's data.\n     */\n    ReasonPhrases[\"REQUESTED_RANGE_NOT_SATISFIABLE\"] = \"Requested Range Not Satisfiable\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.3.6\n     *\n     * This response code is sent after accomplishing request to tell user agent reset document view which sent this request.\n     */\n    ReasonPhrases[\"RESET_CONTENT\"] = \"Reset Content\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.4.4\n     *\n     * Server sent this response to directing client to get requested resource to another URI with an GET request.\n     */\n    ReasonPhrases[\"SEE_OTHER\"] = \"See Other\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.6.4\n     *\n     * The server is not ready to handle the request. Common causes are a server that is down for maintenance or that is overloaded. Note that together with this response, a user-friendly page explaining the problem should be sent. This responses should be used for temporary conditions and the Retry-After: HTTP header should, if possible, contain the estimated time before the recovery of the service. The webmaster must also take care about the caching-related headers that are sent along with this response, as these temporary condition responses should usually not be cached.\n     */\n    ReasonPhrases[\"SERVICE_UNAVAILABLE\"] = \"Service Unavailable\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.2.2\n     *\n     * This code is sent in response to an Upgrade request header by the client, and indicates the protocol the server is switching too.\n     */\n    ReasonPhrases[\"SWITCHING_PROTOCOLS\"] = \"Switching Protocols\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.4.7\n     *\n     * Server sent this response to directing client to get requested resource to another URI with same method that used prior request. This has the same semantic than the 302 Found HTTP response code, with the exception that the user agent must not change the HTTP method used: if a POST was used in the first request, a POST must be used in the second request.\n     */\n    ReasonPhrases[\"TEMPORARY_REDIRECT\"] = \"Temporary Redirect\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc6585#section-4\n     *\n     * The user has sent too many requests in a given amount of time (\"rate limiting\").\n     */\n    ReasonPhrases[\"TOO_MANY_REQUESTS\"] = \"Too Many Requests\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7235#section-3.1\n     *\n     * Although the HTTP standard specifies \"unauthorized\", semantically this response means \"unauthenticated\". That is, the client must authenticate itself to get the requested response.\n     */\n    ReasonPhrases[\"UNAUTHORIZED\"] = \"Unauthorized\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7725\n     *\n     * The user-agent requested a resource that cannot legally be provided, such as a web page censored by a government.\n     */\n    ReasonPhrases[\"UNAVAILABLE_FOR_LEGAL_REASONS\"] = \"Unavailable For Legal Reasons\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc2518#section-10.3\n     *\n     * The request was well-formed but was unable to be followed due to semantic errors.\n     */\n    ReasonPhrases[\"UNPROCESSABLE_ENTITY\"] = \"Unprocessable Entity\";\n    /**\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.5.13\n     *\n     * The media format of the requested data is not supported by the server, so the server is rejecting the request.\n     */\n    ReasonPhrases[\"UNSUPPORTED_MEDIA_TYPE\"] = \"Unsupported Media Type\";\n    /**\n     * @deprecated\n     * Official Documentation @ https://tools.ietf.org/html/rfc7231#section-6.4.6\n     *\n     * Was defined in a previous version of the HTTP specification to indicate that a requested response must be accessed by a proxy. It has been deprecated due to security concerns regarding in-band configuration of a proxy.\n     */\n    ReasonPhrases[\"USE_PROXY\"] = \"Use Proxy\";\n    /**\n     * Official Documentation @ https://datatracker.ietf.org/doc/html/rfc7540#section-9.1.2\n     *\n     * Defined in the specification of HTTP/2 to indicate that a server is not able to produce a response for the combination of scheme and authority that are included in the request URI.\n     */\n    ReasonPhrases[\"MISDIRECTED_REQUEST\"] = \"Misdirected Request\";\n})(ReasonPhrases = exports.ReasonPhrases || (exports.ReasonPhrases = {}));\n", "\"use strict\";\nvar __assign = (this && this.__assign) || function () {\n    __assign = Object.assign || function(t) {\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\n            s = arguments[i];\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n                t[p] = s[p];\n        }\n        return t;\n    };\n    return __assign.apply(this, arguments);\n};\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n    for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p);\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n    return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar legacy_1 = __importDefault(require(\"./legacy\"));\nvar utils_functions_1 = require(\"./utils-functions\");\nvar utils_functions_2 = require(\"./utils-functions\");\nObject.defineProperty(exports, \"getStatusCode\", { enumerable: true, get: function () { return utils_functions_2.getStatusCode; } });\nObject.defineProperty(exports, \"getReasonPhrase\", { enumerable: true, get: function () { return utils_functions_2.getReasonPhrase; } });\nObject.defineProperty(exports, \"getStatusText\", { enumerable: true, get: function () { return utils_functions_2.getStatusText; } });\nvar status_codes_1 = require(\"./status-codes\");\nObject.defineProperty(exports, \"StatusCodes\", { enumerable: true, get: function () { return status_codes_1.StatusCodes; } });\nvar reason_phrases_1 = require(\"./reason-phrases\");\nObject.defineProperty(exports, \"ReasonPhrases\", { enumerable: true, get: function () { return reason_phrases_1.ReasonPhrases; } });\n__exportStar(require(\"./legacy\"), exports);\nexports.default = __assign(__assign({}, legacy_1.default), { getStatusCode: utils_functions_1.getStatusCode,\n    getStatusText: utils_functions_1.getStatusText });\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nexport * from './lib';\nexport * from './utils';\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport { Component, ErrorInfo, ReactNode } from 'react';\n\nimport { routePath } from '../../runtime.router';\n\n/**\n * Props for the ErrorBoundary component\n */\ninterface ErrorBoundaryProps {\n  children: ReactNode;\n  fallback?: ReactNode;\n  onError?: (error: Error, errorInfo: ErrorInfo) => void;\n}\n\n/**\n * State for the ErrorBoundary component\n */\ninterface ErrorBoundaryState {\n  hasError: boolean;\n  error: Error | null;\n  errorInfo: ErrorInfo | null;\n  redirectTimer: number;\n}\n\n/**\n * ErrorBoundary component that catches JavaScript errors anywhere in the child component tree,\n * logs those errors, and displays a fallback UI instead of the component tree that crashed.\n *\n * Features:\n * - Graceful error handling with user-friendly messages\n * - Production vs development error display\n * - Automatic redirect to homepage after timeout\n * - Integration with logging system\n * - Manual error recovery option\n */\nexport class ErrorBoundary extends Component<ErrorBoundaryProps, ErrorBoundaryState> {\n  private redirectInterval?: NodeJS.Timeout;\n  private readonly REDIRECT_TIMEOUT = 10; // seconds\n  private readonly isProduction = typeof window === 'undefined' ? process.env.PURE_ENV_STAGE === 'prod' : false;\n\n  constructor(props: ErrorBoundaryProps) {\n    super(props);\n    this.state = {\n      hasError: false,\n      error: null,\n      errorInfo: null,\n      redirectTimer: this.REDIRECT_TIMEOUT,\n    };\n  }\n\n  /**\n   * Static method called when an error is thrown in a child component.\n   * Updates state to trigger error UI rendering.\n   */\n  static getDerivedStateFromError(error: Error): Partial<ErrorBoundaryState> {\n    return {\n      hasError: true,\n      error,\n    };\n  }\n\n  /**\n   * Lifecycle method called after an error has been thrown by a descendant component.\n   * Used for logging error information.\n   */\n  componentDidCatch(error: Error, errorInfo: ErrorInfo): void {\n    // Log error details\n    console.group('[ErrorBoundary] Error caught');\n    console.error('Error:', error);\n    console.error('Error Info:', errorInfo);\n    console.error('Component Stack:', errorInfo.componentStack);\n    console.groupEnd();\n\n    // Update state with error info\n    this.setState({\n      errorInfo,\n    });\n\n    // Call custom error handler if provided\n    if (this.props.onError) {\n      try {\n        this.props.onError(error, errorInfo);\n      } catch (handlerError) {\n        console.error('[ErrorBoundary] Error in custom error handler:', handlerError);\n      }\n    }\n\n    // Start redirect countdown\n    this.startRedirectCountdown();\n  }\n\n  /**\n   * Starts the countdown timer for automatic redirect to homepage\n   */\n  private startRedirectCountdown(): void {\n    this.redirectInterval = setInterval(() => {\n      this.setState((prevState) => {\n        const newTimer = prevState.redirectTimer - 1;\n\n        if (newTimer <= 0) {\n          this.clearRedirectInterval();\n          this.redirectToHome();\n          return { redirectTimer: 0 };\n        }\n\n        return { redirectTimer: newTimer };\n      });\n    }, 1000);\n  }\n\n  /**\n   * Clears the redirect interval timer\n   */\n  private clearRedirectInterval(): void {\n    if (this.redirectInterval) {\n      clearInterval(this.redirectInterval);\n      this.redirectInterval = undefined;\n    }\n  }\n\n  /**\n   * Redirects to the homepage\n   */\n  private redirectToHome(): void {\n    window.location.href = routePath(['/']);\n  }\n\n  /**\n   * Attempts to recover from the error by resetting state\n   */\n  private handleReset = (): void => {\n    this.clearRedirectInterval();\n    this.setState({\n      hasError: false,\n      error: null,\n      errorInfo: null,\n      redirectTimer: this.REDIRECT_TIMEOUT,\n    });\n  };\n\n  /**\n   * Cleanup on component unmount\n   */\n  componentWillUnmount(): void {\n    this.clearRedirectInterval();\n  }\n\n  render(): ReactNode {\n    if (this.state.hasError) {\n      // Use custom fallback if provided\n      if (this.props.fallback) {\n        return this.props.fallback;\n      }\n\n      // Default error UI with inline styles\n      const styles = {\n        container: {\n          display: 'flex',\n          justifyContent: 'center',\n          alignItems: 'center',\n          minHeight: '100vh',\n          padding: '20px',\n          fontFamily: '-apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif',\n          backgroundColor: '#f5f5f5',\n        } as React.CSSProperties,\n        content: {\n          maxWidth: '800px',\n          width: '100%',\n          backgroundColor: '#ffffff',\n          borderRadius: '8px',\n          padding: '40px',\n          boxShadow: '0 2px 8px rgba(0, 0, 0, 0.1)',\n        } as React.CSSProperties,\n        heading: {\n          fontSize: '2rem',\n          fontWeight: 600,\n          textAlign: 'center' as const,\n          marginBottom: '20px',\n          color: '#333',\n        } as React.CSSProperties,\n        errorBox: {\n          backgroundColor: '#f5f5f5',\n          padding: '16px',\n          borderRadius: '4px',\n          marginBottom: '20px',\n          border: '1px solid #e0e0e0',\n        } as React.CSSProperties,\n        errorTitle: {\n          fontSize: '1.125rem',\n          fontWeight: 600,\n          color: '#d32f2f',\n          marginBottom: '12px',\n        } as React.CSSProperties,\n        errorText: {\n          whiteSpace: 'pre-wrap' as const,\n          wordBreak: 'break-word' as const,\n          fontFamily: 'monospace',\n          fontSize: '0.875rem',\n          color: '#666',\n          maxHeight: '200px',\n          overflow: 'auto',\n          margin: 0,\n        } as React.CSSProperties,\n        message: {\n          fontSize: '1rem',\n          textAlign: 'center' as const,\n          marginBottom: '16px',\n          color: '#666',\n        } as React.CSSProperties,\n        timer: {\n          fontSize: '1rem',\n          textAlign: 'center' as const,\n          marginBottom: '24px',\n          color: '#999',\n        } as React.CSSProperties,\n        buttonContainer: {\n          display: 'flex',\n          justifyContent: 'center',\n          gap: '16px',\n          flexWrap: 'wrap' as const,\n        } as React.CSSProperties,\n        button: {\n          padding: '12px 24px',\n          fontSize: '1rem',\n          fontWeight: 500,\n          borderRadius: '4px',\n          border: 'none',\n          cursor: 'pointer',\n          textDecoration: 'none',\n          display: 'inline-block',\n          transition: 'background-color 0.2s',\n        } as React.CSSProperties,\n        primaryButton: {\n          backgroundColor: '#1976d2',\n          color: '#ffffff',\n        } as React.CSSProperties,\n        secondaryButton: {\n          backgroundColor: '#ffffff',\n          color: '#1976d2',\n          border: '1px solid #1976d2',\n        } as React.CSSProperties,\n      };\n\n      return (\n        <div style={styles.container}>\n          <div style={styles.content}>\n            <h1 style={styles.heading}>\n              {this.isProduction\n                ? 'Something went wrong'\n                : 'An error occurred'}\n            </h1>\n\n            {/* Show error details in development */}\n            {!this.isProduction && this.state.error && (\n              <div style={styles.errorBox}>\n                <div style={styles.errorTitle}>Error Details:</div>\n                <pre style={styles.errorText}>\n                  {this.state.error.toString()}\n                </pre>\n                {this.state.errorInfo && (\n                  <>\n                    <div style={{ ...styles.errorTitle, marginTop: '16px' }}>\n                      Component Stack:\n                    </div>\n                    <pre style={styles.errorText}>\n                      {this.state.errorInfo.componentStack}\n                    </pre>\n                  </>\n                )}\n              </div>\n            )}\n\n            <p style={styles.message}>\n              {this.isProduction\n                ? 'We\\'re sorry for the inconvenience. Please try again.'\n                : 'Check the console for more details.'}\n            </p>\n\n            {this.state.redirectTimer > 0 && (\n              <p style={styles.timer}>\n                {`Redirecting to homepage in ${this.state.redirectTimer} seconds`}\n              </p>\n            )}\n\n            <div style={styles.buttonContainer}>\n              <button\n                style={{ ...styles.button, ...styles.primaryButton }}\n                onClick={this.handleReset}\n                onMouseOver={(e) => {\n                  e.currentTarget.style.backgroundColor = '#1565c0';\n                }}\n                onMouseOut={(e) => {\n                  e.currentTarget.style.backgroundColor = '#1976d2';\n                }}\n              >\n                Try Again\n              </button>\n              <a\n                style={{ ...styles.button, ...styles.secondaryButton }}\n                href={routePath(['/'])}\n                onMouseOver={(e) => {\n                  e.currentTarget.style.backgroundColor = '#f5f5f5';\n                }}\n                onMouseOut={(e) => {\n                  e.currentTarget.style.backgroundColor = '#ffffff';\n                }}\n              >\n                Go to Homepage\n              </a>\n            </div>\n          </div>\n        </div>\n      );\n    }\n\n    return this.props.children;\n  }\n}\n\n/**\n * Legacy functional component for 404 errors (kept for backward compatibility)\n * This is used specifically for route not found errors.\n */\nexport function ErrorBoundaryNotFound() {\n  const timeoutSuccess = 10;\n  const [redirectTimer, setRedirectTimer] = React.useState(timeoutSuccess);\n\n  React.useEffect(() => {\n    if (redirectTimer > 0) {\n      const countdown = setInterval(() => {\n        setRedirectTimer((prev) => prev - 1);\n      }, 1000);\n      return () => clearInterval(countdown);\n    } else {\n      window.location.href = routePath(['/']);\n    }\n  }, [redirectTimer]);\n\n  const styles = {\n    container: {\n      display: 'flex',\n      justifyContent: 'center',\n      alignItems: 'center',\n      minHeight: '100vh',\n      padding: '20px',\n      fontFamily: '-apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, \"Helvetica Neue\", Arial, sans-serif',\n      backgroundColor: '#f5f5f5',\n    } as React.CSSProperties,\n    content: {\n      maxWidth: '800px',\n      width: '100%',\n      backgroundColor: '#ffffff',\n      borderRadius: '8px',\n      padding: '40px',\n      boxShadow: '0 2px 8px rgba(0, 0, 0, 0.1)',\n      textAlign: 'center' as const,\n    } as React.CSSProperties,\n    heading: {\n      fontSize: '2rem',\n      fontWeight: 600,\n      marginBottom: '20px',\n      color: '#333',\n    } as React.CSSProperties,\n    message: {\n      fontSize: '1rem',\n      marginBottom: '16px',\n      color: '#666',\n    } as React.CSSProperties,\n    link: {\n      color: '#1976d2',\n      textDecoration: 'none',\n      fontSize: '1rem',\n      fontWeight: 500,\n    } as React.CSSProperties,\n  };\n\n  return (\n    <div style={styles.container}>\n      <div style={styles.content}>\n        <h1 style={styles.heading}>\n          We couldn't find the page you were looking for.\n        </h1>\n        <p style={styles.message}>\n          {`We'll take you back to the homepage in ${redirectTimer} seconds`}\n        </p>\n        <p style={styles.message}>\n          <a\n            href={routePath(['/'])}\n            style={styles.link}\n            onMouseOver={(e) => {\n              e.currentTarget.style.textDecoration = 'underline';\n            }}\n            onMouseOut={(e) => {\n              e.currentTarget.style.textDecoration = 'none';\n            }}\n          >\n            Click to go to homepage\n          </a>\n        </p>\n      </div>\n    </div>\n  );\n}\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport { useLoaderData } from 'react-router';\n\nimport { RuntimeLoaderResult, SeoMeta } from './runtime.router.types';\n\n/**\n * React hook to access business data from the current route's loader.\n * Extracts and returns only the business property from RuntimeLoaderResult.\n *\n * This hook should be called within a route component that has a loader.\n * It provides type-safe access to data loaded by runtimeAsync retrievers.\n *\n * @template T - The expected type of the business data (defaults to Record<string, unknown>)\n * @returns {T} The business data from the current route's loader\n * @throws {Error} If called outside a route context or if loader data is missing\n *\n * @example\n * // In a route component\n * function ProductPage() {\n *   const { product, reviews } = useRuntimeData<{ product: Product; reviews: Review[] }>();\n *   return <div>{product.name}</div>;\n * }\n *\n * @example\n * // Without type parameter (inferred as Record<string, unknown>)\n * function HomePage() {\n *   const data = useRuntimeData();\n *   return <div>{JSON.stringify(data)}</div>;\n * }\n */\nexport function useRuntimeData<T = Record<string, unknown>>(): T {\n  const loaderData = useLoaderData() as RuntimeLoaderResult | undefined;\n\n  // Check for undefined (outside route context)\n  if (loaderData === undefined) {\n    throw new Error(\n      '[Runtime] useRuntimeData must be called within a route component with a loader. ' +\n      'Ensure the route has a loader function or runtimeAsync retrievers defined.',\n    );\n  }\n\n  // Verify the loader data has the expected structure (check for null and non-object types)\n  if (typeof loaderData !== 'object' || loaderData === null) {\n    throw new Error(\n      '[Runtime] useRuntimeData received invalid loader data. ' +\n      'Expected an object with \"internal\" and \"business\" properties.',\n    );\n  }\n\n  if (!('business' in loaderData)) {\n    throw new Error(\n      '[Runtime] useRuntimeData received loader data without \"business\" property. ' +\n      'This may indicate the route is not using a Runtime-generated loader.',\n    );\n  }\n\n  return loaderData.business as T;\n}\n\n/**\n * React hook to access SEO metadata from the current route's loader.\n * Extracts and returns the seoMeta from the internal property of RuntimeLoaderResult.\n *\n * This hook is primarily used by the RuntimeHeadManager component to update\n * document.title and meta tags during client-side navigation. It can also be\n * used by user components that need access to SEO metadata.\n *\n * @returns {SeoMeta | undefined} The SEO metadata from the current route's loader, or undefined if not available\n *\n * @example\n * // In the head manager component\n * function RuntimeHeadManager() {\n *   const seoMeta = useRuntimeSeoMeta();\n *\n *   useEffect(() => {\n *     if (seoMeta?.title) {\n *       document.title = seoMeta.title;\n *     }\n *   }, [seoMeta]);\n *\n *   return null;\n * }\n *\n * @example\n * // In a user component that needs SEO data\n * function PageHeader() {\n *   const seoMeta = useRuntimeSeoMeta();\n *   return <h1>{seoMeta?.title || 'Default Title'}</h1>;\n * }\n */\nexport function useRuntimeSeoMeta(): SeoMeta | undefined {\n  const loaderData = useLoaderData() as RuntimeLoaderResult | undefined;\n\n  // Return undefined if called outside route context or if loader data is missing\n  if (!loaderData) {\n    return undefined;\n  }\n\n  // Verify the loader data has the expected structure\n  if (typeof loaderData !== 'object' || loaderData === null) {\n    return undefined;\n  }\n\n  if (!('internal' in loaderData)) {\n    return undefined;\n  }\n\n  // Return the seoMeta from internal data (may be undefined)\n  return loaderData.internal?.seoMeta;\n}\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport type { SeoMeta } from './runtime.router.types';\n\n/**\n * Backend SEO metadata type from the API response.\n * This matches the structure returned by the SEO by Route Lambda.\n */\ntype BackendSeoMetaData = {\n  route: string;\n  title: string;\n  description: string;\n  keywords: string[];\n  ogTitle: string;\n  ogDescription: string;\n  ogImage: string;\n  twitterTitle: string;\n  twitterDescription: string;\n  twitterImage: string;\n  canonicalUrl: string;\n  robots: string;\n};\n\n/**\n * Constructs the SEO API URL for a given route.\n * Uses the PURE_ENV_API_BASE_URL environment variable to build the full URL.\n *\n * @param {string} route - The application route to fetch SEO metadata for\n * @returns {string} The full API URL with encoded route parameter\n * @throws {Error} If PURE_ENV_API_BASE_URL is not configured\n *\n * @example\n * constructSeoApiUrl('/about')\n * // Returns: 'https://api.example.com/seo-meta?route=%2Fabout'\n *\n * @example\n * constructSeoApiUrl('/products/123')\n * // Returns: 'https://api.example.com/seo-meta?route=%2Fproducts%2F123'\n */\nexport function constructSeoApiUrl(route: string): string {\n  const apiBaseUrl = process.env.PURE_ENV_API_BASE_URL;\n\n  if (!apiBaseUrl) {\n    throw new Error(\n      '[Runtime] PURE_ENV_API_BASE_URL environment variable is not configured. ' +\n      'Please set this variable to your API Gateway base URL.',\n    );\n  }\n\n  // Remove all trailing slashes from base URL\n  const baseUrl = apiBaseUrl.replace(/\\/+$/, '');\n\n  // Construct the full URL with encoded route parameter\n  return `${baseUrl}/seo-meta?route=${encodeURIComponent(route)}`;\n}\n\n/**\n * Fetches SEO metadata for a specific route from the API Gateway endpoint.\n * Handles errors gracefully and returns null on failure.\n *\n * This function is designed to work in browser environments only.\n * It should not be called during serverless rendering.\n *\n * @param {string} route - The application route to fetch SEO metadata for\n * @returns {Promise<SeoMeta | null>} SEO metadata or null if unavailable\n *\n * @example\n * const seoMeta = await fetchSeoMetadataFromApi('/about');\n * if (seoMeta) {\n *   console.log(seoMeta.title); // \"About Us\"\n * }\n *\n * @example\n * // Handles errors gracefully\n * const seoMeta = await fetchSeoMetadataFromApi('/non-existent');\n * // Returns null and logs warning\n */\nexport async function fetchSeoMetadataFromApi(route: string): Promise<SeoMeta | null> {\n  try {\n    // Construct the API URL\n    const url = constructSeoApiUrl(route);\n\n    // Make the API request\n    const response = await fetch(url);\n\n    if (!response.ok) {\n      // API returned non-OK status (404, 500, etc.)\n      console.warn(\n        `[Runtime] SEO API returned status ${response.status} for route \"${route}\"`,\n      );\n      return null;\n    }\n\n    // Parse the JSON response\n    const data: BackendSeoMetaData = await response.json();\n\n    // Adapt backend format to frontend format\n    return adaptBackendSeoToFrontend(data);\n  } catch (error) {\n    // Handle network errors, JSON parsing errors, or missing environment variable\n    if (error instanceof Error && error.message.includes('PURE_ENV_API_BASE_URL')) {\n      // Re-throw configuration errors so they're visible to developers\n      console.error(error.message);\n    } else {\n      // Log other errors as warnings (network issues, etc.)\n      console.warn(\n        `[Runtime] Failed to fetch SEO metadata from API for route \"${route}\":`,\n        error,\n      );\n    }\n    return null;\n  }\n}\n\n/**\n * Adapts backend SEO metadata type to frontend SeoMeta type.\n * Converts the backend SeoMetaData structure to the frontend SeoMeta structure,\n * ensuring compatibility between backend and frontend data contracts.\n *\n * The backend now returns fully merged SEO metadata (defaults + route-specific),\n * so this function simply maps the fields to the frontend type.\n *\n * @param {BackendSeoMetaData} backend - Backend SEO metadata from API (already merged with defaults)\n * @returns {SeoMeta} Frontend-compatible SEO metadata\n */\nfunction adaptBackendSeoToFrontend(backend: BackendSeoMetaData): SeoMeta {\n  return {\n    title: backend.title,\n    description: backend.description,\n    keywords: backend.keywords,\n    ogTitle: backend.ogTitle,\n    ogDescription: backend.ogDescription,\n    ogImage: backend.ogImage,\n    // Backend doesn't have ogUrl and ogType yet, will be added in future\n    ogUrl: backend.canonicalUrl, // Use canonical URL as fallback\n    ogType: 'website', // Default type\n    twitterCard: 'summary', // Default card type\n    twitterTitle: backend.twitterTitle,\n    twitterDescription: backend.twitterDescription,\n    twitterImage: backend.twitterImage,\n    canonicalUrl: backend.canonicalUrl,\n    robots: backend.robots,\n    // jsonLd is not in backend type yet, will be added in future\n  };\n}\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport type { DataRetriever, DataRetrieverContext, SeoMeta } from './runtime.router.types';\nimport { fetchSeoMetadataFromApi } from './runtime.router.seo.api-client';\n\n/**\n * Creates an internal SEO retriever that fetches SEO metadata for a route.\n * This retriever is automatically added to all routes and executes in parallel\n * with user-provided retrievers.\n *\n * The SEO retriever handles both browser and serverless rendering environments:\n * - Browser: Fetches SEO data from API endpoint (already merged with defaults by Lambda)\n * - Serverless rendering: Returns null (SEO data is already in the page from Lambda)\n *\n * The backend Lambda handler (LambdaRuntimeSeoByRoute) uses SeoProvider to merge\n * route-specific metadata with defaults before returning, ensuring:\n * - Default SEO metadata is always applied as a base\n * - Route-specific metadata is merged on top of defaults\n * - No state leakage occurs between routes\n *\n * @param {string} routePath - The path of the route to fetch SEO metadata for\n * @returns {DataRetriever} A data retriever function that returns SEO metadata\n *\n * @example\n * const seoRetriever = createSeoRetriever('/products/:id');\n * const result = await seoRetriever(context);\n * // result = { seoMeta: { title: '...', description: '...', ... } }\n */\nexport function createSeoRetriever(routePath: string): DataRetriever {\n  return async (ctx: DataRetrieverContext): Promise<Record<string, unknown>> => {\n    try {\n      // Fetch SEO metadata for the route (already merged with defaults by backend)\n      const seoMeta = await fetchSeoMetadata(routePath, ctx);\n\n      return {\n        seoMeta: seoMeta || getDefaultSeoMeta(),\n      };\n    } catch (error) {\n      // SEO retriever is non-critical - log error and return defaults\n      console.warn(`[Runtime] SEO retriever failed for route \"${routePath}\":`, error);\n      return {\n        seoMeta: getDefaultSeoMeta(),\n      };\n    }\n  };\n}\n\n/**\n * Fetches SEO metadata for a route from the backend.\n * Handles both browser and serverless rendering environments differently:\n *\n * - Browser: Makes an API call to fetch SEO data from the dedicated SEO API endpoint\n *   The backend Lambda handler merges route-specific metadata with defaults before returning\n * - Serverless rendering: Returns null (data is already in the page from Lambda serverless rendering)\n *\n * For dynamic routes (e.g., `/products/:id`), route parameters are replaced with\n * actual values from the context before fetching.\n *\n * The returned metadata is already merged with defaults by the backend, ensuring:\n * - All SEO fields have values (either route-specific or default)\n * - No state leakage between routes\n * - Consistent behavior across all routes\n *\n * @param {string} routePath - The route path to fetch SEO metadata for (may contain params like `:id`)\n * @param {DataRetrieverContext} ctx - Context containing route params for dynamic routes\n * @returns {Promise<SeoMeta | null>} SEO metadata (merged with defaults) or null if unavailable\n *\n * @example\n * // For a static route\n * const seoMeta = await fetchSeoMetadata('/about', ctx);\n * // Fetches from: ${PURE_ENV_API_BASE_URL}/seo-meta?route=%2Fabout\n * // Returns: Merged metadata (route-specific + defaults)\n *\n * @example\n * // For a dynamic route\n * const seoMeta = await fetchSeoMetadata('/products/:id', { params: { id: '123' }, ... });\n * // Fetches from: ${PURE_ENV_API_BASE_URL}/seo-meta?route=%2Fproducts%2F123\n * // Returns: Merged metadata (route-specific + defaults)\n */\nexport async function fetchSeoMetadata(\n  routePath: string,\n  ctx: DataRetrieverContext,\n): Promise<SeoMeta | null> {\n  // In serverless rendering environment, SEO data is already in the page from Lambda\n  // The loader data will be hydrated from server, so we don't need to fetch\n  if (typeof window === 'undefined') {\n    return null;\n  }\n\n  // Client-side: fetch from dedicated SEO API endpoint\n  // The backend merges route-specific metadata with defaults before returning\n  try {\n    // Replace route params with actual values for dynamic routes\n    let resolvedPath = routePath;\n    if (ctx.params) {\n      Object.entries(ctx.params).forEach(([key, value]) => {\n        resolvedPath = resolvedPath.replace(`:${key}`, String(value));\n      });\n    }\n\n    // Use the new SEO API client to fetch metadata (already merged with defaults)\n    return await fetchSeoMetadataFromApi(resolvedPath);\n  } catch (error) {\n    console.warn(`[Runtime] Failed to fetch SEO metadata for route \"${routePath}\":`, error);\n    return null;\n  }\n}\n\n/**\n * Returns default SEO metadata as a fallback when fetching fails.\n * These defaults ensure the application always has valid SEO metadata\n * even when the backend is unavailable or returns errors.\n *\n * Includes all SEO fields to ensure proper meta tag management:\n * - Basic meta tags (title, description, robots)\n * - Open Graph tags for social media sharing\n * - Twitter Card tags for Twitter sharing\n * - Canonical URL\n *\n * @returns {SeoMeta} Default SEO metadata object with all fields populated\n */\nexport function getDefaultSeoMeta(): SeoMeta {\n  return {\n    title: 'Runtime Web Application',\n    description: 'A Runtime Web serverless application',\n    robots: 'index, follow',\n    keywords: ['aws', 'serverless', 'react', 'serverless rendering'],\n    ogTitle: 'Runtime Web Application',\n    ogDescription: 'A Runtime Web serverless application',\n    ogImage: '/og-image.png',\n    ogUrl: '/',\n    ogType: 'website',\n    twitterCard: 'summary_large_image',\n    twitterTitle: 'Runtime Web Application',\n    twitterDescription: 'A Runtime Web serverless application',\n    twitterImage: '/twitter-card.png',\n    canonicalUrl: '/',\n  };\n}\n\n\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport { LoaderFunctionArgs } from 'react-router';\n\nimport { DataRetriever, DataRetrieverContext, RuntimeLoaderResult } from './runtime.router.types';\nimport { createSeoRetriever } from './runtime.router.seo';\n\n/**\n * Reserved key name for internal framework data.\n * User retrievers cannot return objects containing this key.\n */\nconst RESERVED_INTERNAL_KEY = 'internal';\n\n/**\n * Represents a retriever with metadata about whether it's internal or user-provided.\n */\ntype RetrieverWithMetadata = {\n  retriever: DataRetriever;\n  isInternal: boolean;\n  name: string;\n};\n\n/**\n * Creates a loader function for a route that executes all data retrievers in parallel.\n * The loader orchestrates both internal framework retrievers (SEO) and user-provided retrievers.\n *\n * This function is called internally by the router transformation logic and is not typically\n * used directly by application developers. It generates React Router-compatible loader functions\n * that execute data retrievers using Promise.allSettled for parallel execution.\n *\n * Key features:\n * - Executes all retrievers in parallel (non-blocking)\n * - Automatically includes internal SEO retriever\n * - Validates user data doesn't contain reserved keys\n * - Separates internal framework data from business data\n * - Logs retriever failures without breaking the route\n *\n * @param {string} routePath - The path of the route this loader is for (used for logging)\n * @param {DataRetriever[]} userRetrievers - Array of user-provided data retriever functions\n * @returns {Function} A React Router loader function that returns RuntimeLoaderResult\n *\n * @example\n * // Internal usage by router transformation\n * const loader = createRouteLoader('/products/:id', [\n *   async ({ params }) => ({ product: await fetchProduct(params.id) }),\n *   async ({ params }) => ({ reviews: await fetchReviews(params.id) })\n * ]);\n *\n * @example\n * // The generated loader returns structured data:\n * // {\n * //   internal: { seoMeta: { title: '...', description: '...' } },\n * //   business: { product: {...}, reviews: [...] }\n * // }\n */\nexport function createRouteLoader(\n  routePath: string,\n  userRetrievers: DataRetriever[],\n): (args: LoaderFunctionArgs) => Promise<RuntimeLoaderResult> {\n  return async (args: LoaderFunctionArgs): Promise<RuntimeLoaderResult> => {\n    const { params, request } = args;\n    const url = new URL(request.url);\n    const searchParams = url.searchParams;\n\n    // Build context for retrievers\n    const context: DataRetrieverContext = {\n      params,\n      request,\n      searchParams,\n    };\n\n    // Collect all retrievers: internal + user\n    const internalRetrievers: RetrieverWithMetadata[] = [\n      {\n        retriever: createSeoRetriever(routePath),\n        isInternal: true,\n        name: 'Internal SEO retriever',\n      },\n    ];\n\n    const userRetrieversWithMetadata: RetrieverWithMetadata[] = userRetrievers.map(\n      (retriever, index) => ({\n        retriever,\n        isInternal: false,\n        name: `User retriever ${index + 1}`,\n      }),\n    );\n\n    const allRetrievers = [...internalRetrievers, ...userRetrieversWithMetadata];\n\n    // Execute all retrievers in parallel using Promise.allSettled\n    const results = await executeRuntimeAsync(allRetrievers, context, routePath);\n\n    // Merge results into structured loader result\n    return mergeLoaderResults(results, allRetrievers, routePath);\n  };\n}\n\n/**\n * Executes all data retrievers in parallel using Promise.allSettled.\n * This ensures that one slow or failing retriever doesn't block others.\n *\n * Promise.allSettled is used instead of Promise.all to ensure that:\n * - All retrievers execute regardless of individual failures\n * - Failed retrievers don't prevent successful ones from completing\n * - Each result (fulfilled or rejected) can be processed independently\n *\n * @param {RetrieverWithMetadata[]} retrievers - Array of retrievers with metadata\n * @param {DataRetrieverContext} context - Context to pass to each retriever\n * @param {string} routePath - Route path for logging purposes\n * @returns {Promise<PromiseSettledResult<Record<string, unknown>>[]>} Array of settled promise results\n *\n * @example\n * // Internal usage\n * const results = await executeRuntimeAsync(\n *   [\n *     { retriever: fetchProduct, isInternal: false, name: 'Product retriever' },\n *     { retriever: fetchReviews, isInternal: false, name: 'Reviews retriever' }\n *   ],\n *   { params: { id: '123' }, request, searchParams },\n *   '/products/:id'\n * );\n * // Returns: [\n * //   { status: 'fulfilled', value: { product: {...} } },\n * //   { status: 'fulfilled', value: { reviews: [...] } }\n * // ]\n */\nexport async function executeRuntimeAsync(\n  retrievers: RetrieverWithMetadata[],\n  context: DataRetrieverContext,\n  routePath: string,\n): Promise<PromiseSettledResult<Record<string, unknown>>[]> {\n  if (retrievers.length === 0) {\n    return [];\n  }\n\n  // Execute all retrievers in parallel\n  const promises = retrievers.map(({ retriever }) => retriever(context));\n\n  return Promise.allSettled(promises);\n}\n\n/**\n * Merges retriever results into a structured RuntimeLoaderResult.\n * Handles both fulfilled and rejected promises, validates reserved keys,\n * and separates internal from business data.\n *\n * Processing logic:\n * - Fulfilled internal retrievers \u2192 merged into `internal` field\n * - Fulfilled user retrievers \u2192 merged into `business` field (after validation)\n * - Rejected retrievers \u2192 logged with context, don't block route rendering\n * - Reserved key violations \u2192 filtered out with warning\n *\n * Future enhancement: Support for fatal retrievers that throw errors on failure.\n *\n * @param {PromiseSettledResult<Record<string, unknown>>[]} results - Results from Promise.allSettled\n * @param {RetrieverWithMetadata[]} retrievers - Original retrievers with metadata\n * @param {string} routePath - Route path for logging purposes\n * @returns {RuntimeLoaderResult} Structured loader result with internal and business data\n * @throws {Error} If a fatal retriever fails (future enhancement)\n *\n * @example\n * // Internal usage\n * const loaderResult = mergeLoaderResults(\n *   [\n *     { status: 'fulfilled', value: { seoMeta: {...} } },\n *     { status: 'fulfilled', value: { product: {...} } },\n *     { status: 'rejected', reason: new Error('Network error') }\n *   ],\n *   [\n *     { retriever: seoRetriever, isInternal: true, name: 'SEO' },\n *     { retriever: productRetriever, isInternal: false, name: 'Product' },\n *     { retriever: reviewsRetriever, isInternal: false, name: 'Reviews' }\n *   ],\n *   '/products/:id'\n * );\n * // Returns: {\n * //   internal: { seoMeta: {...} },\n * //   business: { product: {...} }\n * // }\n * // Note: Reviews retriever failed but didn't break the route\n */\nexport function mergeLoaderResults(\n  results: PromiseSettledResult<Record<string, unknown>>[],\n  retrievers: RetrieverWithMetadata[],\n  routePath: string,\n): RuntimeLoaderResult {\n  const loaderResult: RuntimeLoaderResult = {\n    internal: {},\n    business: {},\n  };\n\n  // @note: read notes below\n  // const fatalErrors: Array<{ name: string; error: Error }> = [];\n\n  results.forEach((result, index) => {\n    const { isInternal, name } = retrievers[index];\n\n    if (result.status === 'fulfilled') {\n      const data = result.value;\n\n      // Validate and merge data based on retriever type\n      if (isInternal) {\n        // Internal retrievers merge into internal field\n        Object.assign(loaderResult.internal, data);\n      } else {\n        // User retrievers: validate reserved key and merge into business field\n        if (RESERVED_INTERNAL_KEY in data) {\n          console.warn(\n            `[Runtime] ${name} for route \"${routePath}\" returned reserved key \"${RESERVED_INTERNAL_KEY}\", ignoring it`,\n          );\n\n          // Filter out the reserved key\n          const { [RESERVED_INTERNAL_KEY]: _, ...rest } = data;\n          Object.assign(loaderResult.business, rest);\n        } else {\n          Object.assign(loaderResult.business, data);\n        }\n      }\n    } else {\n      // Handle rejection - comprehensive error logging\n      logRetrieverFailure(result.reason, name, routePath, isInternal);\n\n      // Future enhancement: Check if retriever is marked as fatal\n      // For now, all retrievers are non-critical\n      // If a retriever had isFatal: true, we would add it to fatalErrors array\n      // Example:\n      // if (retriever.isFatal) {\n      //     fatalErrors.push({ name, error: result.reason });\n      // }\n    }\n  });\n\n  // Future enhancement: Throw aggregate error if any fatal retrievers failed\n  // This would allow React Router's error boundary to catch and display the error\n  // if (fatalErrors.length > 0) {\n  //     throw createAggregateError(fatalErrors, routePath);\n  // }\n\n  return loaderResult;\n}\n\n/**\n * Logs a retriever failure with comprehensive context information.\n * Uses appropriate log levels based on retriever type and criticality.\n *\n * @param {unknown} reason - The error or rejection reason\n * @param {string} retrieverName - Name of the failed retriever\n * @param {string} routePath - Route path where the failure occurred\n * @param {boolean} isInternal - Whether this is an internal framework retriever\n */\nfunction logRetrieverFailure(\n  reason: unknown,\n  retrieverName: string,\n  routePath: string,\n  isInternal: boolean,\n): void {\n  // Extract error details - handle any type of rejection reason safely\n  let error: Error;\n  try {\n    error = reason instanceof Error ? reason : new Error(String(reason));\n  } catch {\n    // If String(reason) fails (e.g., object with broken toString), use JSON.stringify\n    try {\n      error = new Error(JSON.stringify(reason));\n    } catch {\n      // If even JSON.stringify fails, use a generic message\n      error = new Error('[Unable to serialize error reason]');\n    }\n  }\n  const errorMessage = error.message;\n  const stackTrace = error.stack;\n\n  // Log with comprehensive context\n  const logPrefix = '[Runtime Loader Error]';\n  const context = {\n    retriever: retrieverName,\n    route: routePath,\n    type: isInternal ? 'internal' : 'user',\n    timestamp: new Date().toISOString(),\n  };\n\n  // For now, all retrievers are non-critical, so we use console.warn\n  // Future enhancement: support isFatal flag to use console.error for fatal retrievers\n  console.warn(\n    `${logPrefix} ${retrieverName} failed for route \"${routePath}\"`,\n    '\\nError:', errorMessage,\n    '\\nContext:', context,\n  );\n\n  // Log stack trace separately for better readability\n  if (stackTrace) {\n    console.warn(`${logPrefix} Stack trace:`, stackTrace);\n  }\n\n  // In development, provide additional debugging information\n  if (typeof process !== 'undefined' && process.env?.NODE_ENV === 'development') {\n    console.warn(\n      `${logPrefix} Debug info:`,\n      '\\n- Retriever type:', isInternal ? 'Internal framework retriever' : 'User-provided retriever',\n      '\\n- Route:', routePath,\n      '\\n- Error type:', error.constructor.name,\n      '\\n- Timestamp:', context.timestamp,\n    );\n  }\n}\n\n/**\n * Creates an aggregate error from multiple fatal retriever failures.\n * This error can be caught by React Router's error boundary.\n *\n * @param {Array<{name: string; error: Error}>} fatalErrors - Array of fatal errors\n * @param {string} routePath - Route path where failures occurred\n * @returns {Error} Aggregate error with details of all failures\n *\n * @internal This is a future enhancement for fatal retriever support\n */\nfunction createAggregateError(\n  fatalErrors: Array<{ name: string; error: Error }>,\n  routePath: string,\n): Error {\n  const errorMessages = fatalErrors\n    .map(({ name, error }) => `${name}: ${error.message}`)\n    .join('\\n');\n\n  const aggregateError = new Error(\n    `Fatal retriever failures for route \"${routePath}\":\\n${errorMessages}`,\n  );\n\n  // Attach additional context for error boundaries\n  (aggregateError as any).retrieverErrors = fatalErrors;\n  (aggregateError as any).routePath = routePath;\n\n  return aggregateError;\n}\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport { useEffect, useState } from 'react';\nimport { RouterProvider } from 'react-router';\n\n/**\n * Represents the properties that can be used within a component.\n *\n * @typedef {Object} Props\n * @property {any} [router] - An optional property that may contain router-related information or methods.\n */\ntype Props = {\n  router?: any;\n};\n\n/**\n * RuntimeRouterProvider is a React Functional Component that serves as a custom\n * router provider for the application. It wraps around a RouterProvider component\n * and allows for dependency injection of custom router configurations.\n *\n * @param {Object} props - The properties object.\n * @param {Array} props.router - An optional array to define custom router configurations.\n *                                Defaults to an empty array if not provided.\n * @returns {JSX.Element} The wrapped RouterProvider component with the provided custom router.\n */\nexport const RuntimeRouterProvider: React.FC<Props> = ({ router }) => {\n  const [currentRouter, setCurrentRouter] = useState(router);\n\n  useEffect(() => {\n    setCurrentRouter(router);\n  }, [router]);\n\n  return router\n    ? (\n      <RouterProvider\n        key={'runtime-router-provider'}\n        router={currentRouter}\n      />\n    )\n    : null;\n};\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport { Children, cloneElement, isValidElement, ReactElement } from 'react';\n\nimport { InjectRouterOptions, RuntimeRouterProviderProps, ReactComponentProps } from '../runtime.utils.types';\n\n/**\n * Constructs a route path by appending a given path to the base route stage defined\n * in the environment variable 'PURE_ENV_ROUTE_STAGE'. The resulting path is normalized\n * by replacing multiple consecutive slashes with a single slash and ensuring it ends\n * with a trailing slash.\n *\n * @param {string[]} path - An array of path segments to be appended to the base route stage.\n * @returns {string} The normalized route path.\n */\nexport const routePath = (path: string[]) => {\n  return '/'.concat([...path].join('/')).replace(/\\/+/g, '/');\n};\n\n\n/**\n * Injects a routing flow into the provided React children elements by mapping over them and augmenting with the router instance.\n *\n * This method recursively traverses the React component tree and injects the router instance into\n * components that are identified as `RuntimeRouterProvider` by their displayName or name.\n *\n * @param {InjectRouterOptions} params - Contains the children elements to process and the router instance to inject.\n * @param {ReactElement<ReactComponentProps>[]} params.children - The child components to which the router functionality will be injected.\n * @param {any} params.router - The router instance to be injected into the child components.\n * @return {ReactElement<ReactComponentProps>[]} Returns the modified children elements with the router injected where applicable.\n */\nexport function injectFlow(\n  { children, router }: InjectRouterOptions,\n): ReactElement<ReactComponentProps>[] {\n  if (!children) {\n    console.warn('[RuntimeRouter] injectFlow called with no children');\n    return [];\n  }\n\n  if (!router) {\n    console.warn('[RuntimeRouter] injectFlow called with no router');\n    return Children.toArray(children) as ReactElement<ReactComponentProps>[];\n  }\n\n  return Children.map<ReactElement<ReactComponentProps>, ReactElement<ReactComponentProps>>(\n    children,\n    (child: ReactElement<ReactComponentProps>): ReactElement<ReactComponentProps> => {\n      // Skip non-valid React elements\n      if (!isValidElement(child)) {\n        return child;\n      }\n\n      // Check if this is a RuntimeRouterProvider component\n      const typeName = (child.type as any)?.displayName || (child.type as any)?.name;\n\n      if (typeName === 'RuntimeRouterProvider') {\n        console.log('[RuntimeRouter] Injecting router instance into RuntimeRouterProvider');\n        return React.cloneElement(\n          child as ReactElement<RuntimeRouterProviderProps>,\n          { ...child.props, router },\n        );\n      }\n\n      // Recursively process children\n      if ((child.props as ReactComponentProps).children) {\n        return cloneElement(child, {\n          children: injectFlow({\n            children: child.props.children,\n            router,\n          }),\n        });\n      }\n\n      return child;\n    });\n}\n\n/**\n * Computes the intersection of two arrays, returning an array that contains only the elements\n * that are present in both input arrays. Duplicate values in the input arrays are ignored.\n * intersection\n * @param {T[]} arr1 - The first input array.\n * @param {T[]} arr2 - The second input array.\n * @return {T[]} An array containing the elements that are present in both `arr1` and `arr2`.\n */\nexport function intersection<T>(arr1: T[], arr2: T[]): T[] {\n  const set1 = new Set(arr1);\n  const set2 = new Set(arr2);\n  const result: T[] = [];\n\n  Array.from(set1).forEach(item => {\n    if (set2.has(item)) {\n      result.push(item);\n    }\n  });\n\n  return result;\n}\n\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport { RouteObject } from 'react-router';\n\nimport { RuntimeRoute } from './runtime.router.types';\nimport { createRouteLoader } from './runtime.router.loader';\nimport { intersection, routePath } from './runtime.router.utils';\n\n/**\n * Represents the default type for defining route objects in the application.\n * It combines the properties of `RouteObject` with an optional `index` property.\n *\n * @typedef {RouteObject} RuntimeRouterDefaults\n * @property {boolean} [index] Optional property indicating whether the route is an index route.\n */\nexport type RuntimeRouterDefaults = RouteObject & { index?: boolean; [key: string]: any };\n\n/**\n * Represents a router configuration object for the Runtime application.\n *\n * @typedef {Object} RuntimeRouter\n * @property {RuntimeRoute[]} router - An array of Runtime route objects defining the application's routing structure.\n * @property {RuntimeRouterDefaults} [defaults] - Optional default configurations for the router.\n *\n * @todo v2 | GraphQL loaders\n */\nexport type RuntimeRouterOptions = {\n  router: RuntimeRoute[];\n  defaults: RuntimeRouterDefaults;\n  // @todo: v2 | GraphQL loaders\n  // ...\n}\n\nexport class RuntimeRouter {\n  /**\n   * Represents the collection of route configurations for an application.\n   * Each route object defines a path, associated component, and additional options or nested routes.\n   *\n   * The `_router` variable is a map of route objects keyed by route ID, where each object conforms to the\n   * structure defined by the `RouteObject` type. This is typically used in routing libraries\n   * to configure navigation and view rendering.\n   *\n   * @type {Record<string, RouteObject>}\n   */\n  private readonly _router: { [key: string]: RouteObject };\n\n\n  /**\n   * Represents the default configuration settings for a `RuntimeRouter`.\n   *\n   * This variable stores an instance of `RuntimeRouterDefaults`,\n   * which serves as the base configuration for initializing or modifying\n   * a `RuntimeRouter`.\n   *\n   * Adjusting these defaults allows for altering the behavior of\n   * the router to better suit application requirements.\n   *\n   * It is recommended to carefully manage modifications to `_defaults`\n   * to maintain consistent and predictable routing functionality.\n   *\n   * @type {RuntimeRouterDefaults}\n   */\n  private readonly _defaults: RuntimeRouterDefaults;\n\n  /**\n   * Constructs a new instance of the RuntimeRouter with the specified router and default options.\n   *\n   * This constructor transforms RuntimeRoute routes into React Router RouteObject routes,\n   * generating loaders for routes with runtimeAsync and applying default settings.\n   *\n   * @param {Object} options - The options to initialize the constructor with.\n   * @param {RuntimeRoute[]} options.router - Array of Runtime route objects to be managed.\n   * @param {RuntimeRouterDefaults} options.defaults - The default settings for all routes.\n   * @return {void} Initializes the class instance.\n   * @throws {Error} If router array is empty or routes are missing required properties\n   */\n  constructor({ router, defaults }: RuntimeRouterOptions) {\n    // Validate inputs\n    if (!router || !Array.isArray(router) || router.length === 0) {\n      throw new Error('[RuntimeRouter] Invalid routing configuration: route definitions must be provided as a non-empty array');\n    }\n\n    if (!defaults) {\n      throw new Error('[RuntimeRouter] Invalid configuration: runtime configuration router defaults object is required');\n    }\n\n    this._defaults = defaults;\n\n    // Transform RuntimeRoute[] to RouteObject[] with generated loaders\n    const transformedRoutes = this.transformRoutes(router);\n\n    const defaultsKeys: string[] = Object.keys(this._defaults);\n\n    // Build router map with defaults applied\n    this._router = Object.fromEntries(\n      transformedRoutes.map((route: RouteObject, index: number) => {\n        // Ensure route has an ID\n        if (!route.id) {\n          console.warn(`[RuntimeRouter] Route at index ${index} missing ID, generating one`);\n          route.id = `route-${index}`;\n        }\n\n        // Apply defaults to route (only for keys not already present)\n        const routerKeys: string[] = Object.keys(route);\n        const intersected: string[] = intersection(defaultsKeys, routerKeys);\n\n        defaultsKeys.forEach((key: keyof RuntimeRouterDefaults | string) => {\n          if (!intersected.includes(key as string)) {\n            (route as any)[key as keyof RouteObject] = (defaults as any)[key as keyof RouteObject];\n          }\n        });\n\n        return [route.id, route];\n      }),\n    );\n\n    console.log(`[RuntimeRouter] Routing graph initialized with ${Object.keys(this._router).length} route definition(s)`);\n  }\n\n  /**\n   * Transforms an array of RuntimeRoute into React Router RouteObject array.\n   * Recursively processes nested routes and generates loaders for routes with runtimeAsync.\n   *\n   * @param {RuntimeRoute[]} routes - Array of Runtime route objects to transform\n   * @return {RouteObject[]} Array of React Router route objects with generated loaders\n   * @private\n   */\n  private transformRoutes(routes: RuntimeRoute[]): RouteObject[] {\n    return routes.map(route => this.transformRoute(route));\n  }\n\n  /**\n   * Transforms a single RuntimeRoute into a React Router RouteObject.\n   * Generates a loader function if runtimeAsync is present, recursively transforms children,\n   * and ensures runtimeAsync property is not passed to React Router.\n   *\n   * @param {RuntimeRoute} route - Runtime route object to transform\n   * @return {RouteObject} React Router route object with generated loader\n   * @private\n   */\n  private transformRoute(route: RuntimeRoute): RouteObject {\n    const { path, runtimeAsync, children, index, ...routeProps } = route;\n    const routePathname = routePath([path ?? '/']);\n\n\n    // Generate loader for this route\n    // Even routes without runtimeAsync get a loader (for internal SEO retriever)\n    const loader = createRouteLoader(\n      routePathname,\n      runtimeAsync || [],\n    );\n\n    // Recursively transform children\n    const transformedChildren = children\n      ? this.transformRoutes(children)\n      : undefined;\n\n    // Return RouteObject without runtimeAsync property\n    // Note: index routes cannot have loaders, so we exclude index if present\n    const result: RouteObject = {\n      ...routeProps,\n      path: routePathname,\n      loader,\n      children: transformedChildren,\n    };\n\n    // Only add index if it's explicitly false (index routes can't have loaders)\n    if (index === false) {\n      result.index = false;\n    }\n\n    return result;\n  }\n\n  /**\n   * Retrieves all route objects as an array.\n   * This method is used for creating browser routers and serverless rendering static handlers.\n   *\n   * @return {RouteObject[]} Array of all route objects managed by this router\n   */\n  getRoutes(): RouteObject[] {\n    return Object.values(this._router);\n  }\n\n  /**\n   * Finds a route by its ID.\n   *\n   * @param {string} id - The unique identifier of the route\n   * @return {RouteObject | undefined} The route object if found, undefined otherwise\n   */\n  getRouteById(id: string): RouteObject | undefined {\n    return this._router[id];\n  }\n\n  /**\n   * Finds a route by its path.\n   * Useful for serverless rendering route resolution and navigation.\n   *\n   * @param {string} path - The path to search for\n   * @return {RouteObject | undefined} The route object if found, undefined otherwise\n   */\n  getRouteByPath(path: string): RouteObject | undefined {\n    return this.getRoutes().find((route) => route.path === path);\n  }\n\n  /**\n   * Retrieves the current list of route objects managed by the router.\n   *\n   * @return {RouteObject[]} An array of route objects representing the available routes.\n   */\n  get routes(): RouteObject[] {\n    return Object.values(this._router);\n  }\n\n\n  /**\n   * Retrieves the default configuration for the RuntimeRouter.\n   *\n   * @return {RuntimeRouterDefaults} The default settings of the router.\n   */\n  get defaults(): RuntimeRouterDefaults {\n    return this._defaults;\n  }\n}\n\n/**\n * Initializes and returns a new instance of the RuntimeRouter.\n * This is the main entry point for creating a Runtime router with automatic data loading.\n *\n * The router transforms RuntimeRoute routes into React Router routes with generated loaders\n * that execute data retrievers in parallel and manage SEO metadata automatically.\n *\n * @param {RuntimeRouterOptions} options - An object containing configuration options for the router.\n * @return {RuntimeRouter} A new instance of the RuntimeRouter configured with the provided options.\n *\n * @example\n * // Basic usage with runtimeAsync data retrievers\n * import { runtimeRouter } from '@worktif/runtime';\n *\n * const router = runtimeRouter({\n *   router: [\n *     {\n *       path: '/',\n *       element: <HomePage />,\n *       runtimeAsync: [\n *         async ({ params, request, searchParams }) => {\n *           const data = await fetchHomeData();\n *           return { homeData: data };\n *         }\n *       ]\n *     },\n *     {\n *       path: '/products/:id',\n *       element: <ProductPage />,\n *       runtimeAsync: [\n *         async ({ params }) => {\n *           const product = await fetchProduct(params.id);\n *           return { product };\n *         },\n *         async ({ params }) => {\n *           const reviews = await fetchReviews(params.id);\n *           return { reviews };\n *         }\n *       ]\n *     }\n *   ],\n *   defaults: {\n *     errorElement: <ErrorBoundary />\n *   }\n * });\n *\n * @example\n * // Using the router with Runtime Router\n * import { RuntimeRouterProvider } from '@worktif/runtime';\n *\n * function App() {\n *   return <RuntimeRouterProvider router={router} />;\n * }\n *\n * @example\n * // Accessing data in components\n * import { useRuntimeData } from '@worktif/runtime';\n *\n * function ProductPage() {\n *   const { product, reviews } = useRuntimeData<{ product: Product; reviews: Review[] }>();\n *\n *   return (\n *     <div>\n *       <h1>{product.name}</h1>\n *       <p>{product.description}</p>\n *       <ReviewList reviews={reviews} />\n *     </div>\n *   );\n * }\n */\nexport function runtimeRouter(options: RuntimeRouterOptions): RuntimeRouter {\n  return new RuntimeRouter(options);\n}\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport { useEffect, useRef } from 'react';\nimport { useLocation, useMatches } from 'react-router';\n\nimport { RuntimeLoaderResult } from '../runtime.router';\n\n// Track if a head manager instance is already mounted\nlet headManagerInstanceCount = 0;\n\n/**\n * Head manager component that updates document.title and meta tags on route changes.\n * This component subscribes to route loader changes and updates the document head\n * with SEO metadata for client-side navigation.\n *\n * Features:\n * - Updates document.title based on seoMeta.title\n * - Creates/updates meta tags for description, keywords, robots\n * - Manages Open Graph tags for social media sharing\n * - Manages Twitter card tags\n * - Handles JSON-LD structured data\n * - Preserves Serverless rendering tags on hydration\n * - Avoids duplicate meta tags\n * - Handles edge cases: undefined/null metadata, inaccessible document.head, multiple instances\n *\n * **Important**: Place this component at the root level of your application, inside the RouterProvider.\n * Only one instance should be mounted per application.\n *\n * @returns {null} This component doesn't render anything\n *\n * @example\n * // Basic usage with RouterProvider\n * import { RuntimeHeadManager, RuntimeWebRouterProvider } from '@worktif/runtime';\n *\n * function App({ router }) {\n *   return (\n *     <>\n *       <RuntimeHeadManager />\n *       <YourAppContent />\n *     </>\n *   );\n * }\n *\n * @example\n * // Complete setup with runtimeRouter\n * import { runtimeRouter, RuntimeHeadManager, RuntimeWebRouterProvider } from '@worktif/runtime';\n *\n * const router = runtimeRouter({\n *   router: [\n *     {\n *       path: '/',\n *       element: <HomePage />,\n *       runtimeAsync: [\n *         async () => ({ homeData: await fetchHomeData() })\n *       ]\n *     }\n *   ],\n *   defaults: {}\n * });\n *\n * function App() {\n *   return (\n *     <>\n *       <RuntimeHeadManager />\n *       <Outlet />\n *     </>\n *   );\n * }\n *\n * @example\n * // The head manager automatically updates meta tags when navigating\n * // If your route loader returns SEO metadata like this:\n * // { internal: { seoMeta: { title: 'Product Page', description: '...' } } }\n * //\n * // The head manager will automatically:\n * // 1. Update document.title to 'Product Page'\n * // 2. Update meta description tag\n * // 3. Update Open Graph tags\n * // 4. Update Twitter card tags\n * // 5. Update JSON-LD structured data\n */\nexport function RuntimeHeadManager(): null {\n  const location = useLocation();\n  const matches = useMatches();\n  const isMountedRef = useRef(false);\n\n  console.debug(`[Runtime] Route change detected, syncing <head> for path: `, location.pathname);\n\n  // Detect multiple head manager instances on mount\n  useEffect(() => {\n    if (!isMountedRef.current) {\n      headManagerInstanceCount++;\n      isMountedRef.current = true;\n\n      if (headManagerInstanceCount > 1) {\n        console.warn(\n          `[Runtime] Multiple RuntimeHeadManager instances detected (${headManagerInstanceCount}). ` +\n          'Only one instance should be mounted at the root of your application. ' +\n          'Multiple instances may cause unexpected behavior.',\n        );\n      }\n    }\n\n    // Cleanup on unmount\n    return () => {\n      if (isMountedRef.current) {\n        headManagerInstanceCount--;\n        isMountedRef.current = false;\n      }\n    };\n  }, []);\n\n  useEffect(() => {\n    // Check if document.head is accessible\n    if (typeof document === 'undefined' || !document.head) {\n      console.warn('[Runtime] document.head is not accessible. Skipping head updates.');\n      return;\n    }\n\n    // Get the last match (current route)\n    const currentMatch = matches[matches.length - 1];\n    const loaderData = currentMatch?.data as RuntimeLoaderResult | undefined;\n    const seoMeta = loaderData?.internal?.seoMeta;\n\n    // Skip if no SEO metadata (undefined or null)\n    if (!seoMeta || seoMeta === null) {\n      return;\n    }\n\n    try {\n      // Update document title (only if different to prevent flickering)\n      if (seoMeta.title && document.title !== seoMeta.title) {\n        document.title = seoMeta.title;\n      }\n\n      // @todo: implement ability to customise meta-tags HTML resolver\n      //        Custom measn RuntimeWebRouterProvider property to marge current and custom approaches\n      // Update basic meta tags\n      updateMetaTag('description', seoMeta.description);\n      updateMetaTag('keywords', seoMeta.keywords?.join(', '));\n      updateMetaTag('robots', seoMeta.robots);\n\n      // Update Open Graph tags\n      updateMetaProperty('og:title', seoMeta.ogTitle);\n      updateMetaProperty('og:description', seoMeta.ogDescription);\n      updateMetaProperty('og:image', seoMeta.ogImage);\n      updateMetaProperty('og:url', seoMeta.ogUrl);\n      updateMetaProperty('og:type', seoMeta.ogType);\n\n      // Update Twitter card tags\n      updateMetaName('twitter:card', seoMeta.twitterCard);\n      updateMetaName('twitter:title', seoMeta.twitterTitle);\n      updateMetaName('twitter:description', seoMeta.twitterDescription);\n      updateMetaName('twitter:image', seoMeta.twitterImage);\n\n      // Update canonical URL\n      updateLinkTag('canonical', seoMeta.canonicalUrl);\n\n      // Update JSON-LD\n      updateJsonLd(seoMeta.jsonLd);\n    } catch (error) {\n      console.error('[Runtime] Error updating document head:', error);\n    }\n  }, [location, matches]);\n\n  return null;\n}\n\n/**\n * Updates or creates a meta tag with a name attribute.\n * Reuses existing tags to avoid duplicates.\n * Only updates if content differs from existing value to prevent flickering.\n * Removes the tag if content is empty to prevent stale values from previous routes.\n * Handles edge cases: null/undefined content, inaccessible document.head, DOM errors.\n *\n * @param {string} name - The name attribute value\n * @param {string | undefined} content - The content attribute value\n */\nfunction updateMetaTag(name: string, content: string | undefined): void {\n  try {\n    // Check if document.head is accessible\n    if (!document.head) {\n      console.warn(`[Runtime] Cannot update meta tag \"${name}\": document.head is not accessible`);\n      return;\n    }\n\n    // Find existing tag (with or without our marker)\n    let meta = document.querySelector(`meta[name=\"${name}\"][data-runtime-meta]`) as HTMLMetaElement | null;\n    if (!meta) {\n      meta = document.querySelector(`meta[name=\"${name}\"]`) as HTMLMetaElement | null;\n    }\n\n    // If content is empty, remove the tag to prevent stale values\n    if (!content || content === null || content.trim() === '') {\n      if (meta) {\n        meta.remove();\n      }\n      return;\n    }\n\n    // Escape content to prevent XSS\n    const escapedContent = escapeHtml(content);\n\n    if (!meta) {\n      // Create new tag\n      meta = document.createElement('meta');\n      meta.setAttribute('name', name);\n      meta.setAttribute('data-runtime-meta', 'true');\n      document.head.appendChild(meta);\n    } else {\n      // Mark existing tag as ours\n      meta.setAttribute('data-runtime-meta', 'true');\n    }\n\n    // Only update if content differs\n    if (meta.getAttribute('content') !== escapedContent) {\n      meta.setAttribute('content', escapedContent);\n    }\n  } catch (error) {\n    console.warn(`[Runtime] Failed to update meta tag \"${name}\":`, error);\n  }\n}\n\n/**\n * Updates or creates a meta tag with a property attribute (for Open Graph tags).\n * Reuses existing tags to avoid duplicates.\n * Only updates if content differs from existing value to prevent flickering.\n * Removes the tag if content is empty to prevent stale values from previous routes.\n * Handles edge cases: null/undefined content, inaccessible document.head, DOM errors.\n *\n * @param {string} property - The property attribute value\n * @param {string | undefined} content - The content attribute value\n */\nfunction updateMetaProperty(property: string, content: string | undefined): void {\n  try {\n    // Check if document.head is accessible\n    if (!document.head) {\n      console.warn(`[Runtime] Cannot update meta property \"${property}\": document.head is not accessible`);\n      return;\n    }\n\n    // Find existing tag (with or without our marker)\n    let meta = document.querySelector(`meta[property=\"${property}\"][data-runtime-meta]`) as HTMLMetaElement | null;\n    if (!meta) {\n      meta = document.querySelector(`meta[property=\"${property}\"]`) as HTMLMetaElement | null;\n    }\n\n    // If content is empty, remove the tag to prevent stale values\n    if (!content || content === null || content.trim() === '') {\n      if (meta) {\n        meta.remove();\n      }\n      return;\n    }\n\n    // Escape content to prevent XSS\n    const escapedContent = escapeHtml(content);\n\n    if (!meta) {\n      // Create new tag\n      meta = document.createElement('meta');\n      meta.setAttribute('property', property);\n      meta.setAttribute('data-runtime-meta', 'true');\n      document.head.appendChild(meta);\n    } else {\n      // Mark existing tag as ours\n      meta.setAttribute('data-runtime-meta', 'true');\n    }\n\n    // Only update if content differs\n    if (meta.getAttribute('content') !== escapedContent) {\n      meta.setAttribute('content', escapedContent);\n    }\n  } catch (error) {\n    console.warn(`[Runtime] Failed to update meta property \"${property}\":`, error);\n  }\n}\n\n/**\n * Updates or creates a meta tag with a name attribute (specifically for Twitter cards).\n * Reuses existing tags to avoid duplicates.\n * Only updates if content differs from existing value to prevent flickering.\n * Removes the tag if content is empty to prevent stale values from previous routes.\n * Handles edge cases: null/undefined content, inaccessible document.head, DOM errors.\n *\n * @param {string} name - The name attribute value\n * @param {string | undefined} content - The content attribute value\n */\nfunction updateMetaName(name: string, content: string | undefined): void {\n  try {\n    // Check if document.head is accessible\n    if (!document.head) {\n      console.warn(`[Runtime] Cannot update meta name \"${name}\": document.head is not accessible`);\n      return;\n    }\n\n    // Find existing tag (with or without our marker)\n    let meta = document.querySelector(`meta[name=\"${name}\"][data-runtime-meta]`) as HTMLMetaElement | null;\n    if (!meta) {\n      meta = document.querySelector(`meta[name=\"${name}\"]`) as HTMLMetaElement | null;\n    }\n\n    // If content is empty, remove the tag to prevent stale values\n    if (!content || content === null || content.trim() === '') {\n      if (meta) {\n        meta.remove();\n      }\n      return;\n    }\n\n    // Escape content to prevent XSS\n    const escapedContent = escapeHtml(content);\n\n    if (!meta) {\n      // Create new tag\n      meta = document.createElement('meta');\n      meta.setAttribute('name', name);\n      meta.setAttribute('data-runtime-meta', 'true');\n      document.head.appendChild(meta);\n    } else {\n      // Mark existing tag as ours\n      meta.setAttribute('data-runtime-meta', 'true');\n    }\n\n    // Only update if content differs\n    if (meta.getAttribute('content') !== escapedContent) {\n      meta.setAttribute('content', escapedContent);\n    }\n  } catch (error) {\n    console.warn(`[Runtime] Failed to update meta name \"${name}\":`, error);\n  }\n}\n\n/**\n * Updates or creates a link tag with a rel attribute (for canonical URL).\n * Reuses existing tags to avoid duplicates.\n * Only updates if href differs from existing value to prevent flickering.\n * Removes the tag if href is empty to prevent stale values from previous routes.\n * Handles edge cases: null/undefined href, inaccessible document.head, DOM errors.\n *\n * @param {string} rel - The rel attribute value\n * @param {string | undefined} href - The href attribute value\n */\nfunction updateLinkTag(rel: string, href: string | undefined): void {\n  try {\n    // Check if document.head is accessible\n    if (!document.head) {\n      console.warn(`[Runtime] Cannot update link tag \"${rel}\": document.head is not accessible`);\n      return;\n    }\n\n    // Find existing tag (with or without our marker)\n    let link = document.querySelector(`link[rel=\"${rel}\"][data-runtime-link]`) as HTMLLinkElement | null;\n    if (!link) {\n      link = document.querySelector(`link[rel=\"${rel}\"]`) as HTMLLinkElement | null;\n    }\n\n    // If href is empty, remove the tag to prevent stale values\n    if (!href || href === null || href.trim() === '') {\n      if (link) {\n        link.remove();\n      }\n      return;\n    }\n\n    // Escape href to prevent XSS\n    const escapedHref = escapeHtml(href);\n\n    if (!link) {\n      // Create new tag\n      link = document.createElement('link');\n      link.setAttribute('rel', rel);\n      link.setAttribute('data-runtime-link', 'true');\n      document.head.appendChild(link);\n    } else {\n      // Mark existing tag as ours\n      link.setAttribute('data-runtime-link', 'true');\n    }\n\n    // Only update if href differs\n    if (link.getAttribute('href') !== escapedHref) {\n      link.setAttribute('href', escapedHref);\n    }\n  } catch (error) {\n    console.warn(`[Runtime] Failed to update link tag \"${rel}\":`, error);\n  }\n}\n\n/**\n * Updates or creates a JSON-LD script tag for structured data.\n * Removes the script tag if jsonLd is undefined or null.\n * Only updates if content differs from existing value to prevent flickering.\n * Handles edge cases: null/undefined jsonLd, inaccessible document.head, serialization errors.\n *\n * @param {Record<string, unknown> | undefined} jsonLd - The JSON-LD object to serialize\n */\nfunction updateJsonLd(jsonLd: Record<string, unknown> | undefined): void {\n  try {\n    // Check if document.head is accessible\n    if (!document.head) {\n      console.warn('[Runtime] Cannot update JSON-LD: document.head is not accessible');\n      return;\n    }\n\n    let script = document.querySelector('script[data-runtime-jsonld]') as HTMLScriptElement | null;\n\n    // Remove script if jsonLd is null, undefined, or empty\n    if (!jsonLd || jsonLd === null) {\n      if (script) {\n        script.remove();\n      }\n      return;\n    }\n\n    // Serialize JSON-LD content\n    const jsonString = JSON.stringify(jsonLd);\n\n    if (!script) {\n      // Check if there's an existing tag without our marker (from serverless rendering)\n      script = document.querySelector('script[type=\"application/ld+json\"]') as HTMLScriptElement | null;\n      if (script && !script.hasAttribute('data-runtime-jsonld')) {\n        // Mark it as ours\n        script.setAttribute('data-runtime-jsonld', 'true');\n        // Only update if content differs from serverless rendering\n        if (script.textContent !== jsonString) {\n          script.textContent = jsonString;\n        }\n        return;\n      } else if (!script) {\n        // Create new script tag\n        script = document.createElement('script');\n        script.setAttribute('type', 'application/ld+json');\n        script.setAttribute('data-runtime-jsonld', 'true');\n        document.head.appendChild(script);\n      }\n    }\n\n    // Only update if content differs\n    if (script.textContent !== jsonString) {\n      script.textContent = jsonString;\n    }\n  } catch (error) {\n    console.error('[Runtime] Failed to update JSON-LD:', error);\n  }\n}\n\n/**\n * Escapes HTML special characters to prevent XSS attacks.\n * Handles edge cases: null/undefined text, DOM errors.\n *\n * @param {string} text - The text to escape\n * @returns {string} The escaped text\n */\nfunction escapeHtml(text: string): string {\n  // Handle null/undefined\n  if (!text || text === null) {\n    return '';\n  }\n\n  try {\n    const div = document.createElement('div');\n    div.textContent = text;\n    return div.innerHTML;\n  } catch (error) {\n    // Fallback to manual escaping if DOM manipulation fails\n    console.warn('[Runtime] DOM-based HTML escaping failed, using fallback:', error);\n    return text\n      .replace(/&/g, '&amp;')\n      .replace(/</g, '&lt;')\n      .replace(/>/g, '&gt;')\n      .replace(/\"/g, '&quot;')\n      .replace(/'/g, '&#039;');\n  }\n}\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport { useEffect, useState } from 'react';\n\n// import './App.css';\n\ntype Props = {\n  children?: any;\n};\n\n/**\n * A React functional component that wraps its children in a styled container with\n * a fade-in effect upon mounting. This component is primarily used to manage the\n * visibility and transition effects of its children.\n *\n * The fade-in effect is controlled using internal state hooks that determine the\n * `opacity` and visibility of the component after mounting. Styles are dynamically\n *\n * applied to facilitate the transition.\n *\n * @type {React.FC<Props>}\n * @param {Props} props - The props object that includes the children elements to be wrapped.\n * @property {React.ReactNode} props.children - The content to be rendered inside the component.\n * @remarks\n * - Internal state `mounted` manages the initial setup for visibility and positioning\n *   before the component is fully mounted.\n * - Internal state `fadeIn` controls the gradual appearance of the component after the\n *   mounting is initialized.\n * - Uses `useEffect` to trigger the fade-in transition with a brief delay.\n * - Styled using inline `Box` styles to handle positioning, visibility, and transition effects.\n */\nexport const RuntimeAppServer: React.FC<Props> = ({ children }) => {\n  // @important: framework, package\n  const [mounted, setMounted] = useState(false);\n  const [fadeIn, setFadeIn] = useState(false);\n\n  useEffect(() => {\n    setMounted(true);\n\n    const timeout = setTimeout(() => {\n      setFadeIn(true);\n    }, 10);\n\n    return () => clearTimeout(timeout);\n  }, []);\n\n  //------ @important: framework, package\n\n  return (\n    <div\n      style={{\n        position: mounted ? 'relative' : 'absolute',\n        top: mounted ? 'auto' : '-9999px',\n        left: mounted ? 'auto' : '-9999px',\n        visibility: mounted ? 'visible' : 'hidden',\n        pointerEvents: mounted ? 'auto' : 'none',\n        opacity: fadeIn ? 1 : 0,\n        transition: 'opacity 0.6s ease-in-out',\n      }}\n    >\n      {children}\n    </div>\n  );\n};\n\nexport default RuntimeAppServer;\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport { RouteObject, RouterState, StaticHandlerContext } from 'react-router';\n\nimport { StatusCodes } from 'http-status-codes';\n\nimport { RuntimeRouter } from './runtime.router';\n\n\n/**\n * Indicates whether the code is running in a browser environment.\n * The value is `true` if the `window` object is defined, which signifies\n * a client-side environment, and `false` otherwise.\n *\n * This variable can be used to distinguish between server-side\n * and client-side execution.\n */\nexport const isBrowser = typeof window !== 'undefined' &&\n  typeof document !== 'undefined';\n\n/**\n * Finds a matching route for the given pathname within a route object hierarchy.\n *\n * @param {RouteObject} route - The route object to search within, which may contain child routes.\n * @param {string} pathname - The pathname to match against the route object.\n * @return {RouterState['matches'][number] | null} An object representing the matching route and details,\n * or null if no matching route is found.\n */\nfunction findMatchingRoute(\n  route: RouteObject,\n  pathname: string,\n): RouterState['matches'][number] | null {\n  if (\n    route.path === pathname ||\n    (route.path?.includes(':') && matchDynamicRoute(route.path, pathname))\n  ) {\n    return {\n      params: extractParams(route.path, pathname),\n      pathname,\n      route: route as RouterState['matches'][number]['route'],\n      // pathnameBase: `/${process.env.PURE_ENV_STAGE}/`,\n      pathnameBase: '/',\n    };\n  }\n\n  if (route.children) {\n    for (const child of route.children) {\n      const match = findMatchingRoute(child, pathname);\n      if (match) return match;\n    }\n  }\n\n  return null;\n}\n\n/**\n * Matches a dynamic route with a given pathname by comparing their segments.\n * Dynamic route parameters are prefixed with a colon (:) and can match any string segment.\n *\n * @param {string} routePath The route path string, which may include dynamic segments prefixed with a colon (:).\n * @param {string} pathname The pathname to be matched against the route path.\n * @return {boolean} Returns true if the routePath matches the pathname, considering dynamic segments; otherwise returns false.\n */\nfunction matchDynamicRoute(routePath: string, pathname: string): boolean {\n  const routeSegments = routePath.split('/');\n  const pathnameSegments = pathname.split('/');\n  if (routeSegments.length !== pathnameSegments.length) return false;\n\n  return routeSegments.every(\n    (segment, index) =>\n      segment.startsWith(':') || segment === pathnameSegments[index],\n  );\n}\n\n/**\n * Extracts route parameters from a given pathname based on a specified route path.\n *\n * @param {string} routePath - The route path containing parameter markers (e.g., '/users/:id').\n * @param {string} pathname - The actual pathname to extract parameters from (e.g., '/users/123').\n * @return {Record<string, string>} A key-value mapping of parameter names to their corresponding values from the pathname.\n */\nfunction extractParams(\n  routePath: string,\n  pathname: string,\n): Record<string, string> {\n  const params: Record<string, string> = {};\n  const routeSegments = routePath.split('/');\n  const pathnameSegments = pathname.split('/');\n\n  routeSegments.forEach((segment, index) => {\n    if (segment.startsWith(':')) {\n      params[segment.substring(1)] = pathnameSegments[index];\n    }\n  });\n\n  return params;\n}\n\n/**\n * Processes and returns the context necessary for static route handling.\n *\n * This function takes a location object and a router instance, analyzes the URL path and query parameters,\n * and determines matching routes. It constructs and returns a `StaticHandlerContext` object, which contains\n * details about the current route matching state, loader/action data, status code, error boundaries, and more.\n * It is particularly useful for server-side rendering and static route analysis.\n *\n * @param {RouterState['location']} location - The location object representing the current URL state (path and query parameters).\n * @param {RuntimeRouter} router - The router instance containing route definitions and defaults.\n * @returns {StaticHandlerContext} - The context object representing the state of the route handling process,\n * including matching routes, loader and action data, status codes, and error information.\n */\nexport const routerContext = (\n  location: RouterState['location'],\n  router: RuntimeRouter,\n): StaticHandlerContext => {\n  if (location.search.length > 0 && !location.search.startsWith('?')) {\n    location.search = `?${location.search}`;\n  }\n\n  const pathname = location.pathname.includes(\n    process.env.PURE_ENV_STAGE!,\n  )\n    ? location.pathname.replace(`/${process.env.PURE_ENV_STAGE}`, '/')\n    : location.pathname;\n\n  const matches = router.routes\n    .map((route: RouteObject) => findMatchingRoute(route, pathname))\n    .filter(Boolean) as RouterState['matches'];\n\n  if (matches.length === 0) {\n    console.warn('[Runtime] No matching routes found for:', location.pathname);\n  }\n\n  return {\n    // basename: `/${process.env.PURE_ENV_STAGE}/`,\n    basename: '/',\n    matches: matches ?? [],\n    location,\n    loaderData: {},\n    actionData: {},\n    errors:\n      matches.length === 0\n        ? {\n          '4': {\n            path: `/${StatusCodes.NOT_FOUND}}`,\n            id: '4',\n            Component: router.defaults.ErrorBoundary,\n            ErrorBoundary: router.defaults.ErrorBoundary,\n            hasErrorBoundary: true,\n          },\n        }\n        : null,\n    statusCode: matches.length > 0 ? 200 : 404,\n    loaderHeaders: {},\n    actionHeaders: {},\n    // _deepestRenderedBoundaryId: Math.floor(100000 + Math.random() * 900000).toString(),\n  };\n};\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport { createBrowserRouter, RouterState } from 'react-router';\nimport { createRoot, hydrateRoot } from 'react-dom/client';\n\nimport { isBrowser, routerContext } from './react.utils';\nimport RuntimeAppServer from './runtime.app.server';\nimport { RuntimeRouter } from './runtime.router';\nimport { isLambdaRuntime } from './runtime.utils';\n\nimport { RuntimeThreads } from '../runtime.types';\n\n// Type alias for optional values\ntype Maybe<T> = T | undefined;\n\n// Constant for empty string\nconst EMPTY_STRING = '';\n\n/**\n * Represents the runtime instance of a core bundle, which may or may not be defined.\n *\n * This variable is initialized with an undefined value and can be later assigned\n * to a valid `CoreBundle` instance if applicable.\n *\n * The use of `Maybe` type indicates that the runtime can either hold a `CoreBundle`\n * instance or stay undefined.\n */\nexport let runtimeThreads: Maybe<RuntimeThreads> = void 0;\n\n/**\n * Configures and initializes the Runtime application with the provided options.\n *\n * This function operates in different modes based on the execution context:\n * - Lambda Runtime: Skips rendering when running in AWS Lambda (serverless rendering handled separately)\n * - Browser Runtime: Initializes and renders the React application with hydration support\n *\n * @param {RuntimeThreads} runtimeThreadsInstance - The configuration options for the Runtime application.\n * @return {void} This function does not return a value.\n * @throws {Error} If required configuration is missing or invalid\n */\nexport function runtime(runtimeThreadsInstance: RuntimeThreads): void {\n  // Store runtime configuration\n  runtimeThreads = {\n    ...runtimeThreadsInstance,\n  };\n\n  // Validate required configuration\n  if (!runtimeThreadsInstance) {\n    throw new Error('[Runtime] Invalid configuration: runtime threads configuration object is required');\n  }\n\n  if (!runtimeThreadsInstance.app || typeof runtimeThreadsInstance.app !== 'function') {\n    throw new Error('[Runtime] Invalid configuration: application entry function is required');\n  }\n\n  if (!runtimeThreadsInstance.router || !(runtimeThreadsInstance.router instanceof RuntimeRouter)) {\n    throw new Error('[Runtime] Invalid configuration: router instance is required');\n  }\n\n  console.log('[Runtime] Web runtime initialization started with configuration: ', {\n    hasApp: !!runtimeThreadsInstance.app,\n    hasRouter: !!runtimeThreadsInstance.router,\n    serviceName: runtimeThreadsInstance.config?.serviceName,\n    stage: runtimeThreadsInstance.config?.stage,\n  });\n\n  // Skip rendering in Lambda runtime (serverless rendering is handled by Lambda handler)\n  if (isLambdaRuntime()) {\n    console.log('[Runtime] Lambda runtime detected, skipping browser rendering pipeline');\n    return void 0;\n  }\n\n  // Render React application in browser\n  try {\n    renderReactApp(runtimeThreadsInstance);\n  } catch (error) {\n    console.error('[Runtime] Web runtime render failed:', error);\n    throw error;\n  }\n}\n\n/**\n * Renders the specified React application with the provided configuration options.\n * The method handles server-side hydration if serverless rendering HTML exists, otherwise initializes a new React root element.\n *\n * @param {RuntimeThreads} appOptions - Configuration object containing the router configuration and application component.\n * @returns {void} This method does not return a value.\n * @throws {Error} If required DOM elements are missing or rendering fails\n */\nfunction renderReactApp(appOptions: RuntimeThreads): void {\n  // @todo: include custom logger to evaluate DEBUG or DEV to display logs, excluding production environment\n  console.log('[Runtime] Web runtime boot sequence started...');\n\n  // Ensure we're in a browser environment\n  if (!isBrowser) {\n    console.warn('[Runtime] Non-browser environment detected, skipping web runtime rendering');\n    return;\n  }\n\n  // Double-check Lambda runtime (should not reach here in Lambda)\n  if (isLambdaRuntime()) {\n    console.warn('[Runtime] Lambda runtime detected, skipping web runtime boot');\n    return void 0;\n  }\n\n  // Get DOM elements\n  const rootElement = document.getElementById('root-internal') as HTMLElement;\n  const rootRuntime = document.getElementById('root-runtime') as HTMLElement;\n\n  // Serverless rendering Hydration Path: rootRuntime exists with serverless rendering HTML\n  if (rootRuntime?.hasChildNodes()) {\n    console.log('[Runtime] Pre-rendered DOM snapshot confirmed, binding client runtime...');\n\n    try {\n      // Remove fallback root element if it exists\n      rootElement && rootElement.remove();\n      // if (rootElement) {\n      //   rootElement.remove();\n      // console.log('[Runtime] Temporary fallback node removed'); // @todo: this log is related to DEBUG logs level\n      // }\n\n      // Check if PURE_ENV_STAGE is defined\n      try {\n        const stage = process.env.PURE_ENV_STAGE;\n      } catch (error) {\n        console.warn('\\x1b[33m%s\\x1b[0m', '[WARNING] PURE_ENV_STAGE environment variable is not defined. This may cause unexpected behavior in the application. Please set PURE_ENV_STAGE (e.g., dev, staging, prod)');\n      }\n\n      const stage = process.env.PURE_ENV_STAGE\n\n      // Normalize pathname by removing stage prefix if present\n      const pathname = window.location.pathname.includes(stage!)\n        ? window.location.pathname.replace(`/${stage}/`, '/')\n        : window.location.pathname;\n\n      console.log('[Runtime] Route context loaded for:', pathname);\n\n      // Build location object for router context\n      const location: RouterState['location'] = {\n        pathname: pathname,\n        search: window.location.search,\n        hash: window.location.hash || EMPTY_STRING,\n        key: 'default',\n        state: null,\n      };\n\n      // Create router context with matched routes\n      const context: any = routerContext(location, appOptions.router);\n      console.log('[Runtime] Routing graph resolved (', context.matches?.length || 0, 'match(es))');\n\n      // Create browser router with hydration data\n      const routerBrowser = createBrowserRouter(appOptions.router.routes, {\n        hydrationData: context,\n      });\n\n      // Inject router into app component tree\n      // const appRouted: ReactElement<ReactComponentProps, string | React.JSXElementConstructor<any>>[] = injectFlow({\n      //   children: appOptions.app({ router: routerBrowser }) as ReactElement<ReactComponentProps>,\n      //   router: appOptions.router,\n      // });\n\n      const AppRouted = () => appOptions.app({ router: routerBrowser });\n\n      // Hydrate the serverless rendering HTML\n      hydrateRoot(\n        rootRuntime,\n        <RuntimeAppServer>\n          <AppRouted/>\n        </RuntimeAppServer>,\n        {\n          onRecoverableError: (error, errorInfo) => {\n            // Log hydration errors in non-production environments\n            // if (process.env.PURE_ENV_STAGE !== 'prod') {\n            //   console.group('[Runtime] Hydration Error');\n            //   console.error('Error:', error);\n            //   console.error('Error Info:', errorInfo);\n            //   console.groupEnd();\n            // }\n          },\n        },\n      );\n\n      console.log('[Runtime] Web runtime boot sequence finished successfully');\n    } catch (error) {\n      console.error('[Runtime] Web runtime boot sequence failed:', error);\n      throw new Error(`[Runtime] Web runtime boot sequence failed: ${error instanceof Error ? error.message : String(error)}`);\n    }\n  }\n  // Fresh Render Path: No serverless rendering HTML, create new root\n  else {\n    console.log('[Runtime] No pre-rendered DOM snapshot found, creating fresh application root');\n\n    // Ensure root element exists\n    if (!rootElement) {\n      throw new Error('[Runtime] Root element \"root-internal\" not found in DOM. Ensure your HTML includes <div id=\"root-internal\"></div>');\n    }\n\n    try {\n      // Create browser router without hydration data\n      const routerBrowser: any = createBrowserRouter(appOptions.router.getRoutes());\n\n      // Create React root\n      const root = createRoot(rootElement);\n\n      // Inject router into app component tree\n      // const appRouted: ReactElement<ReactComponentProps, string | React.JSXElementConstructor<any>>[] = injectFlow({\n      //   children: appOptions.app({ router: routerBrowser }) as ReactElement<ReactComponentProps>,\n      //   router: appOptions.router,\n      // });\n\n      const AppRouted = () => appOptions.app({ router: routerBrowser });\n\n      // Render the application\n      root.render(\n        <React.StrictMode>\n          <AppRouted/>\n        </React.StrictMode>,\n      );\n\n      console.log('[Runtime] Fresh web runtime render completed successfully');\n    } catch (error) {\n      console.error('[Runtime] Fresh web runtime render failed:', error);\n      throw new Error(`[Runtime] Render error details:: ${error instanceof Error ? error.message : String(error)}`);\n    }\n  }\n}\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\n/**\n * Checks if the current environment is a Lambda or serverless runtime.\n *\n * The function inspects environment variables commonly set by various\n * serverless platforms like AWS Lambda, Vercel, Netlify, Google Cloud Functions, etc.\n *\n * @return {boolean} Returns true if the environment matches serverless runtime conditions, otherwise false.\n */\nexport function isLambdaRuntime(): boolean {\n  return typeof window === 'undefined'\n    ? Object.keys(process.env)\n      .some((key: string) => [\n        'AWS_LAMBDA_FUNCTION_NAME',\n        'LAMBDA_TASK_ROOT',\n        'FUNCTIONS_WORKER_RUNTIME',\n        'WEBSITE_INSTANCE_ID',\n        'FUNCTION_NAME',\n        'K_SERVICE',\n        'VERCEL',\n        'NETLIFY',\n        'FAAS_ENV',\n        '__OW_ACTION_NAME',\n      ].includes(key))\n    : false;\n}\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensing under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport { hydrateRoot } from 'react-dom/client';\nimport { createBrowserRouter, RouterProvider } from 'react-router';\n\nimport type { BrowserMetadata, RuntimeWebConfig } from '@lib/runtime-web/types';\n\n// import { logger } from '@worktif/utils';\n\n/**\n * Browser execution pipeline for Runtime Web Core.\n *\n * @todo: ordinate this class to infra or core cause we have Node.js responsibility\n *      ---- OR \u2013> REMOVE LOGGER\n *\n * **ARCHITECTURE NOTE**: This file is in `src/lib/` because it:\n * - Uses browser-only APIs (window, document, hydrateRoot)\n * - Runs ONLY in browser environment\n * - Must be isomorphic-safe (no Node.js APIs)\n * - NEVER runs in Lambda\n *\n * Handles client-side hydration of React applications with pre-loaded data\n * from server-side rendering. Sets up client-side routing and HTTP client\n * for post-hydration API calls to Lambda endpoints.\n *\n * **Execution Flow**:\n * 1. Hydrate React app with existing RuntimeRouter\n * 2. Call config.app({ router }) to get React element\n * 3. Initialize client-side navigation\n * 4. Set up HTTP client for Lambda endpoint calls\n *\n * **Requirements**: REQ-06, REQ-12\n */\nexport class BrowserPipeline {\n  // private readonly logger = logger({\n  //   serviceName: '@lib/runtime-web/pipelines/browser-pipeline',\n  // });\n\n  /**\n   * Execute browser pipeline for client-side hydration.\n   *\n   * Hydrates the React application with pre-loaded data from serverless rendering and sets up\n   * client-side routing. Uses React hydration (not render) to match the\n   * server-rendered HTML exactly.\n   *\n   * @param config - Runtime configuration with app factory and router\n   * @param context - Browser environment context with metadata\n   *\n   * @example\n   * ```typescript\n   * const pipeline = new BrowserPipeline();\n   * await pipeline.execute(config, {\n   *   type: 'browser',\n   *   metadata: {\n   *     userAgent: navigator.userAgent,\n   *     url: window.location.href,\n   *     viewport: { width: window.innerWidth, height: window.innerHeight }\n   *   }\n   * });\n   * ```\n   */\n  async execute(config: RuntimeWebConfig, context: { type: 'browser'; metadata: BrowserMetadata }): Promise<void> {\n    try {\n      console.info('Starting browser pipeline execution', {\n        serviceName: config.serviceName,\n        stage: config.stage,\n        url: context.metadata.url,\n        userAgent: context.metadata.userAgent,\n        viewport: context.metadata.viewport,\n      });\n\n      // 1. Create browser router from RuntimeRouter\n      const browserRouter = this.createBrowserRouter(config);\n\n      // 2. Get React element from app factory\n      const appElement = this.createAppElement(config);\n\n      // 3. Create router provider with the app\n      const routerProvider = React.createElement(RouterProvider, {\n        router: browserRouter,\n      }, appElement);\n\n      // 4. Hydrate the application (use hydration, not render)\n      this.hydrateApplication(routerProvider);\n\n      // 5. Set up HTTP client for post-hydration API calls\n      this.setupHttpClient(config);\n\n      console.info('Browser pipeline execution completed successfully', {\n        serviceName: config.serviceName,\n        stage: config.stage,\n      });\n\n    } catch (error) {\n      console.error('Browser pipeline execution failed', {\n        serviceName: config.serviceName,\n        stage: config.stage,\n        error: error instanceof Error ? error.message : String(error),\n        stack: error instanceof Error ? error.stack : undefined,\n      });\n      throw error;\n    }\n  }\n\n  /**\n   * Create browser router from RuntimeRouter configuration.\n   *\n   * Uses the existing RuntimeRouter to get routes and creates a React Router\n   * browser router for client-side navigation.\n   *\n   * @param config - Runtime configuration\n   * @returns Browser router instance\n   * @private\n   */\n  private createBrowserRouter(config: RuntimeWebConfig) {\n    console.debug('Creating browser router', {\n      routeCount: config.router.getRoutes().length,\n    });\n\n    // Get routes from RuntimeRouter\n    const routes = config.router.getRoutes();\n\n    // Create browser router with routes (cast to RouteObject[] for compatibility)\n    const browserRouter = createBrowserRouter(routes as any);\n\n    console.debug('Browser router created successfully', {\n      routeCount: routes.length,\n    });\n\n    return browserRouter;\n  }\n\n  /**\n   * Create React element from app factory function.\n   *\n   * Calls the user's app factory function with the router dependency\n   * to get the root React element for the application.\n   *\n   * @param config - Runtime configuration\n   * @returns Root React element\n   * @private\n   */\n  private createAppElement(config: RuntimeWebConfig): React.ReactElement {\n    console.debug('Creating app element from factory');\n\n    try {\n      // Call app factory with router dependency\n      const appElement = config.app({ router: config.router });\n\n      if (!React.isValidElement(appElement)) {\n        throw new Error('App factory must return a valid React element');\n      }\n\n      console.debug('App element created successfully');\n      return appElement;\n\n    } catch (error) {\n      console.error('Failed to create app element', {\n        error: error instanceof Error ? error.message : String(error),\n      });\n      throw new Error(`Failed to create app element: ${error instanceof Error ? error.message : String(error)}`);\n    }\n  }\n\n  /**\n   * Hydrate the React application in the browser.\n   *\n   * Uses React's hydrateRoot to hydrate the server-rendered HTML with\n   * the client-side React application. This ensures the client matches\n   * the server exactly to avoid hydration mismatches.\n   *\n   * @param routerProvider - Router provider element to hydrate\n   * @private\n   */\n  private hydrateApplication(routerProvider: React.ReactElement): void {\n    console.debug('Starting React hydration');\n\n    try {\n      // Get the root container element\n      const container = document.getElementById('root');\n      if (!container) {\n        throw new Error('Root container element not found. Expected element with id=\"root\"');\n      }\n\n      // Hydrate the application (not render - must match server HTML)\n      hydrateRoot(container, routerProvider);\n\n      console.info('React hydration completed successfully');\n\n    } catch (error) {\n      console.error('React hydration failed', {\n        error: error instanceof Error ? error.message : String(error),\n      });\n      throw new Error(`React hydration failed: ${error instanceof Error ? error.message : String(error)}`);\n    }\n  }\n\n  /**\n   * Set up HTTP client for Lambda endpoint calls.\n   *\n   * Configures the HTTP client for making API calls to Lambda endpoints\n   * after hydration. This is used for post-hydration interactions that\n   * require server-side data.\n   *\n   * @param config - Runtime configuration\n   * @private\n   */\n  private setupHttpClient(config: RuntimeWebConfig): void {\n    console.debug('Setting up HTTP client for Lambda endpoints');\n\n    try {\n      // Set up base URL for API calls based on stage\n      const baseUrl = this.getApiBaseUrl(config.stage);\n\n      // Store configuration globally for use by data loaders\n      if (typeof window !== 'undefined') {\n        (window as any).__RUNTIME_CONFIG__ = {\n          serviceName: config.serviceName,\n          stage: config.stage,\n          apiBaseUrl: baseUrl,\n        };\n      }\n\n      console.info('HTTP client configured successfully', {\n        baseUrl,\n        stage: config.stage,\n      });\n\n    } catch (error) {\n      console.error('Failed to setup HTTP client', {\n        error: error instanceof Error ? error.message : String(error),\n      });\n      throw new Error(`Failed to setup HTTP client: ${error instanceof Error ? error.message : String(error)}`);\n    }\n  }\n\n  /**\n   * Get API base URL based on deployment stage.\n   *\n   * Determines the appropriate API base URL for making HTTP requests\n   * to Lambda endpoints based on the deployment stage.\n   *\n   * @param stage - Deployment stage\n   * @returns API base URL\n   * @private\n   */\n  private getApiBaseUrl(stage: 'dev' | 'staging' | 'prod'): string {\n    // In browser context, API calls go through the same origin\n    // The actual API Gateway URL is handled by CloudFront routing\n    const origin = typeof window !== 'undefined' ? window.location.origin : '';\n\n    // API endpoints are typically under /api path\n    return `${origin}/api`;\n  }\n}\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\nimport { RouteObject } from 'react-router';\n\nimport type { InfraOptions } from './infra.types';\nimport type { MicroserviceDefinition } from './microservice.types';\nimport { RuntimeRouterDefaults } from '../../runtime-core';\n\n/**\n * RuntimeRouter interface for runtime-web integration.\n *\n * Defines the essential methods needed by the runtime-web pipelines.\n * This interface matches the actual RuntimeRouter class from @lib/runtime-core/runtime.router.\n */\ninterface RuntimeRouterInterface {\n  /**\n   * Get all route objects as an array.\n   * Used for creating browser routers and serverless rendering static handlers.\n   */\n  getRoutes(): Array<RouteObject>;\n\n  /**\n   * Find a route by its ID.\n   */\n  getRouteById?(id: string): RouteObject | undefined;\n\n  /**\n   * Find a route by its path.\n   */\n  getRouteByPath?(path: string): RouteObject | undefined;\n\n  /**\n   * Get the routes array (getter).\n   */\n  routes?: Array<RouteObject>;\n\n  /**\n   * Get the default configuration.\n   */\n  defaults?: RuntimeRouterDefaults;\n}\n\n/**\n * Stage environment for deployment.\n *\n * - `dev`: Development environment\n * - `staging`: Staging/pre-production environment\n * - `prod`: Production environment\n */\nexport type Stage = 'dev' | 'staging' | 'prod';\n\n/**\n * Utility type to extract service names from register configuration.\n *\n * This enables compile-time validation of service names and provides\n * type-safe access to service identifiers throughout the framework.\n *\n * @template T - The register configuration object type\n */\nexport type ServiceNames<T extends Record<string, MicroserviceDefinition>> = keyof T;\n\n/**\n * Utility type to generate Lambda IDs from service configuration.\n *\n * Combines service names with Lambda IDs to create fully qualified\n * Lambda identifiers for type-safe Lambda resolution.\n *\n * @template T - The register configuration object type\n */\nexport type LambdaIds<T extends Record<string, MicroserviceDefinition>> = {\n  [K in keyof T]: T[K]['lambdas'][number] extends { id: infer I }\n    ? I extends string\n      ? `${K & string}.${I}`\n      : never\n    : never;\n}[keyof T];\n\n/**\n * Type constraint for valid service names.\n *\n * Ensures service names follow the validation pattern:\n * - Must start with a letter (a-z, A-Z)\n * - Can contain letters, numbers, and hyphens\n * - Maximum length: 128 characters\n *\n * This is a branded type that provides compile-time validation.\n */\nexport type ValidServiceName = string & { readonly __brand: 'ValidServiceName' };\n\n/**\n * Type guard to validate service name format.\n *\n * @param serviceName - The service name to validate\n * @returns Type predicate indicating if the service name is valid\n */\nexport function isValidServiceName(serviceName: string): serviceName is ValidServiceName {\n  return /^[a-zA-Z][a-zA-Z0-9-]{0,127}$/.test(serviceName);\n}\n\n/**\n * Main configuration interface for Runtime Web Core.\n *\n * This interface provides a unified configuration that works across all execution contexts:\n * - Browser: Hydrates React application with client-side routing\n * - Lambda: Executes server-side rendering and business logic\n * - CDK: Synthesizes CloudFormation infrastructure\n *\n * @template TRegister - The register configuration type for type-safe service names\n *\n * @example\n * ```typescript\n * import { runtime } from '@worktif/runtime/runtime-web';\n * import { RuntimeRouter } from '@worktif/runtime';\n *\n * const config = {\n *   app: ({ router }) => <App router={router} />,\n *   router: new RuntimeRouter({ router: routes, defaults: {} }),\n *   serviceName: 'my-app',\n *   stage: 'dev',\n *   register: {\n *     payments: {\n *       ties: [PaymentsTies],\n *       lambdas: [chargeHandler, refundHandler]\n *     },\n *     users: {\n *       ties: [UsersTies],\n *       lambdas: [createUserHandler, getUserHandler]\n *     }\n *   } as const,  // Use 'as const' for better type inference\n *   infra: {\n *     env: { account: '123456789012', region: 'us-east-1' },\n *     stage: 'dev',\n *     reactEntry: './src/index.tsx',\n *     apiMode: 'apiGateway'\n *   }\n * } satisfies RuntimeWebConfig;\n *\n * runtime(config);\n * ```\n *\n * @todo: after RuntimeWeb repo will be resolved, RuntimeWebConfig MUST extend RuntimeWebConfig Core\n */\nexport interface RuntimeWebConfig<TRegister extends Record<string, MicroserviceDefinition> = Record<string, MicroserviceDefinition>> {\n  /**\n   * React application component factory function.\n   *\n   * Receives the router instance as a dependency and returns the root React element.\n   * This pattern enables dependency injection of the router into your application.\n   *\n   * @param deps - Dependencies object containing the router\n   * @param deps.router - RuntimeRouter instance for navigation and routing\n   * @returns Root React element (React.ReactElement)\n   *\n   * @example\n   * ```typescript\n   * app: ({ router }) => <App router={router} />\n   * ```\n   */\n  app: (deps: { router: RuntimeRouterInterface }) => React.ReactElement;\n\n  /**\n   * RuntimeRouter instance for application routing.\n   *\n   * Defines all routes, loaders, and navigation configuration.\n   * The router is used in both server-side rendering (Lambda) and client-side hydration (browser).\n   *\n   * @see {@link RuntimeRouterInterface} for router configuration\n   *\n   * @example\n   * ```typescript\n   * router: new RuntimeRouter({\n   *   router: [\n   *     { path: '/', element: <Home /> },\n   *     { path: '/about', element: <About /> }\n   *   ],\n   *   defaults: {}\n   * })\n   * ```\n   */\n  router: RuntimeRouterInterface;\n\n  /**\n   * Service name identifier for the application.\n   *\n   * Used as a prefix for all AWS resources (Lambda functions, API Gateway, S3 buckets, etc.).\n   * Must be unique within your AWS account and region.\n   *\n   * **Validation Rules**:\n   * - Must start with a letter (a-z, A-Z)\n   * - Can contain letters, numbers, and hyphens\n   * - Maximum length: 128 characters\n   * - Pattern: `/^[a-zA-Z][a-zA-Z0-9-]{0,127}$/`\n   *\n   * **Examples**:\n   * - Valid: `my-app`, `MyApp`, `app123`, `my-app-v2`\n   * - Invalid: `123app` (starts with number), `my_app` (underscore), `my app` (space)\n   *\n   * @example\n   * ```typescript\n   * serviceName: 'my-application'\n   * ```\n   */\n  serviceName: string;\n\n  /**\n   * Deployment stage/environment.\n   *\n   * Determines the environment-specific configuration and resource naming.\n   * Used to create separate infrastructure stacks for different environments.\n   *\n   * **Values**:\n   * - `dev`: Development environment (local testing, rapid iteration)\n   * - `staging`: Staging/pre-production environment (QA, integration testing)\n   * - `prod`: Production environment (live users)\n   *\n   * **Impact**:\n   * - Resource naming: `{serviceName}-{resource}-{stage}`\n   * - Environment variables: Different configs per stage\n   * - Cache TTL: Shorter in dev, longer in prod\n   * - Logging: More verbose in dev, structured in prod\n   *\n   * @example\n   * ```typescript\n   * stage: 'dev'\n   * ```\n   */\n  stage: Stage;\n\n  /**\n   * Microservice registry (runtime-level configuration).\n   *\n   * **Required**: Defines all microservices, their DI containers, and Lambda endpoints.\n   * **Used in all contexts**: Browser (for type generation), Lambda (for DI), CDK (for infrastructure).\n   * **Architecture**: This is runtime configuration, separate from infrastructure concerns.\n   *\n   * Each microservice gets its own PureContainer instance built from the Ties classes.\n   * Lambda functions are automatically created and wired with dependency injection.\n   *\n   * **Type Safety**: Service names are derived from object keys, ensuring compile-time validation.\n   * **No Magic Strings**: All service identifiers are type-safe and auto-generated.\n   *\n   * @see {@link MicroserviceDefinition} for microservice structure\n   *\n   * @example\n   * ```typescript\n   * register: {\n   *   payments: {\n   *     ties: [PaymentsTies, BillingTies],\n   *     lambdas: [chargeHandler, refundHandler, webhookHandler]\n   *   },\n   *   users: {\n   *     ties: [UsersTies, AuthTies],\n   *     lambdas: [createUserHandler, getUserHandler, loginHandler]\n   *   }\n   * } as const  // Use 'as const' for better type inference\n   * ```\n   */\n  register: TRegister;\n\n  /**\n   * Infrastructure configuration for CDK deployment.\n   *\n   * **Optional**: Only required when running in CDK context (synthesizing CloudFormation templates).\n   * **Not used**: In browser and Lambda contexts (runtime configuration is in register).\n   * **Pure infrastructure**: Contains only AWS resource configuration, no business logic.\n   *\n   * Defines:\n   * - AWS account and region\n   * - Lambda configuration (memory, timeout, VPC)\n   * - API Gateway or Lambda URL mode\n   * - Custom domain configuration\n   * - React entry point for serverless rendering Lambda\n   *\n   * @see {@link InfraOptions} for detailed configuration options\n   *\n   * @example\n   * ```typescript\n   * infra: {\n   *   env: { account: '123456789012', region: 'us-east-1' },\n   *   stage: 'dev',\n   *   reactEntry: './src/index.tsx',\n   *   apiMode: 'apiGateway',\n   *   lambdaMemorySize: 1024,\n   *   lambdaTimeout: 30,\n   *   domain: {\n   *     rootDomain: 'myapp.com',\n   *     subdomain: 'api'\n   *   }\n   * }\n   * ```\n   */\n  infra?: InfraOptions;\n}\n\n/**\n * Type-safe Runtime configuration with inferred service names.\n *\n * This type provides enhanced type safety by inferring service names from the register\n * configuration, enabling compile-time validation of service references.\n *\n * @template TRegister - The register configuration type\n */\nexport type TypeSafeRuntimeWebConfig<TRegister extends Record<string, MicroserviceDefinition>> =\n  RuntimeWebConfig<TRegister> & {\n  /**\n   * Type-safe service names derived from register keys.\n   * Available at compile-time for type checking and IDE autocomplete.\n   */\n  readonly serviceNames?: ServiceNames<TRegister>;\n\n  /**\n   * Type-safe Lambda IDs derived from register configuration.\n   * Available at compile-time for type checking and IDE autocomplete.\n   */\n  readonly lambdaIds?: LambdaIds<TRegister>;\n};\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport * as React from 'react';\n\nimport { CloudBundleConfig, CloudBundleConfigType } from './runtime.cloud.types';\nimport { RuntimeRouter } from './runtime-core/runtime.router/runtime.router';\nimport { ReactComponentProps } from './runtime-core/runtime.utils.types';\n\n/**\n * Represents the SEO metadata structure used throughout the application.\n * This is a partial type allowing optional fields for flexible configuration.\n */\nexport type SeoMetaData = {\n  route?: string;\n  title?: string;\n  description?: string;\n  keywords?: string[];\n  ogTitle?: string;\n  ogDescription?: string;\n  ogImage?: string;\n  twitterTitle?: string;\n  twitterDescription?: string;\n  twitterImage?: string;\n  canonicalUrl?: string;\n  robots?: string;\n};\n\n/**\n * SeoMiddleware is a middleware function type designed to process SEO-related\n * metadata by taking in various options and returning an object containing SEO\n * metadata details.\n *\n * It is commonly used in applications for enhancing web pages with SEO\n * attributes such as title, description, canonical URL, and meta tags.\n *\n * @typedef {function} SeoMiddlewareFn\n * @param {...any} options - A list of options or parameters that the middleware\n * function can interpret to generate SEO metadata.\n * @returns {SeoMetaData} An object containing the processed SEO metadata.\n */\nexport type SeoMiddlewareFn = (...options: any) => Promise<any[]>;\n\n/**\n * Represents the configuration options for the Runtime application.\n * This type defines the properties and expected types for initializing\n * and managing the application, including UI structure, routing, SEO,\n * and cloud bundle settings.\n */\nexport type RuntimeThreads = {\n  /**\n   * Represents a React component or element.\n   * The `app` variable is intended to store a ReactElement that defines the structure\n   * and behavior of a portion or the entire user interface of the application.\n   *\n   * This element is used as a React application and can be rendered\n   * into the DOM or other render targets supported by React.\n   *\n   * Type: React.ReactElement\n   */\n  app: React.FC<ReactComponentProps>;\n\n  /**\n   * Configuration object that defines the settings and parameters for a specific cloud bundle type.\n   * This variable uses the `CloudBundleConfig` interface and associates it with\n   * a `CloudBundleConfigType` to specify the specific configuration details.\n   *\n   * @type {CloudBundleConfig[CloudBundleConfigType]}\n   *\n   * @todo: add config schema validation\n   */\n  config: CloudBundleConfig[CloudBundleConfigType];\n\n  /**\n   * Represents a collection of route objects used for defining application routing.\n   * Each RouteObject in the array specifies a single route configuration, including\n   * path, component, child routes, and additional settings.\n   *\n   * The `router` variable allows for declarative routing and is typically used\n   * in conjunction with a routing library to manage navigation and rendering components\n   * based on the URL path.\n   *\n   * Type: `Router[]`\n   */\n  router: RuntimeRouter;\n\n  /**\n   * An optional middleware function designed to handle SEO (Search Engine Optimization) processing.\n   * This middleware may be used to modify, analyze, or enhance server responses,\n   * including setting metadata, titles, descriptions, or headers for better search engine visibility.\n   *\n   * @type {SeoMiddlewareFn | undefined}\n   */\n  seoMiddleware?: SeoMiddlewareFn;\n\n  /**\n   * Optional default SEO metadata to be used as the base-level defaults throughout the application.\n   * These defaults are used by the SEO service when:\n   * - No route-specific SEO metadata exists in DynamoDB\n   * - No default SEO metadata exists in DynamoDB (route `[seo-defaults]`)\n   *\n   * If not provided, the framework will fall back to hardcoded defaults.\n   *\n   * Priority order:\n   * 1. Route-specific metadata from DynamoDB (highest priority)\n   * 2. Default metadata from DynamoDB (`[seo-defaults]` route)\n   * 3. Initialization defaults (this property)\n   * 4. Hardcoded framework defaults (lowest priority)\n   *\n   * @type {Partial<SeoMetaData> | undefined}\n   *\n   * @example\n   * runtime({\n   *   app: App,\n   *   router: myRouter,\n   *   config: myConfig,\n   *   defaultSeoMeta: {\n   *     title: 'My Application',\n   *     description: 'Welcome to my application',\n   *     keywords: ['app', 'react', 'serverless rendering'],\n   *     ogImage: '/images/og-default.png',\n   *     twitterCard: 'summary_large_image'\n   *   }\n   * });\n   */\n  defaultSeoMeta?: Partial<SeoMetaData>;\n};\n\n\nexport enum EnginesBrowserFramework {\n  React = 'react',\n  Angular = 'angular',\n  Vue = 'vue',\n  Svelte = 'svelte',\n  SvelteKit = 'sveltekit',\n  Solid = 'solid',\n  Polymer = 'polymer',\n  Ember = 'ember',\n  Preact = 'preact',\n  Riot = 'riot',\n}\n\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-15, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\nimport { z } from 'zod';\n\n const AWS_REGIONS = [\n  'us-east-1',\n  'us-east-2',\n  'us-west-1',\n  'us-west-2',\n  'eu-west-1',\n  'eu-west-2',\n  'eu-west-3',\n  'eu-central-1',\n  'eu-central-2',\n  'eu-north-1',\n  'eu-south-1',\n  'eu-south-2',\n  'ap-southeast-1',\n  'ap-southeast-2',\n  'ap-southeast-3',\n  'ap-south-1',\n  'ap-south-2',\n  'ap-northeast-1',\n  'ap-northeast-2',\n  'ap-northeast-3',\n  'ap-east-1',\n  'sa-east-1',\n  'ca-central-1',\n  'me-south-1',\n  'me-central-1',\n  'af-south-1',\n] as const;\n\nexport const AwsRegionSchema = z.enum(AWS_REGIONS);\n\n/**\n * Stage configuration for deployment environments.\n *\n * Defines environment-specific settings for deploying Runtime Web applications to AWS.\n * Each stage represents a separate deployment environment (development, staging, production)\n * with its own AWS resources and configuration.\n *\n * @example\n * ```typescript\n * const devStage: StageConfig = {\n *   name: 'dev',\n *   awsRegion: 'us-east-1',\n *   awsProfile: 'my-dev-profile',\n *   domain: 'example.com',\n *   subdomain: 'dev'\n * };\n * ```\n */\nexport const StageConfigSchema = z.object({\n  /**\n   * Stage name identifier.\n   *\n   * Must be one of: 'dev', 'staging', or 'prod'.\n   * This value is used to namespace AWS resources and select environment-specific configuration.\n   *\n   * @example 'dev' | 'staging' | 'prod'\n   */\n  name: z.enum(['dev', 'staging', 'prod']),\n\n  /**\n   * AWS region for deployment.\n   *\n   * The AWS region where CloudFormation stacks, Lambda functions, S3 buckets,\n   * and other resources will be deployed. Must be a valid AWS region identifier.\n   *\n   * @example 'us-east-1' | 'eu-west-1' | 'ap-southeast-2'\n   */\n  awsRegion: z.string().min(1),\n\n  /**\n   * AWS CLI profile name (optional).\n   *\n   * If specified, the CLI will use this AWS profile from your ~/.aws/credentials file\n   * for authentication. If omitted, uses the default AWS credential chain.\n   *\n   * @example 'my-company-dev' | 'production-deployer'\n   */\n  awsProfile: z.string().optional(),\n\n  /**\n   * Custom domain name (optional).\n   *\n   * The root domain for your application. When specified along with subdomain,\n   * the application will be accessible at `subdomain.domain`.\n   * Requires DNS configuration and ACM certificate setup.\n   *\n   * @example 'example.com' | 'myapp.io'\n   */\n  domain: z.string().optional(),\n\n  /**\n   * Subdomain prefix (optional).\n   *\n   * The subdomain prefix for this stage. Combined with domain to form the full URL.\n   * Typically used to separate environments (e.g., 'dev', 'staging', 'www').\n   *\n   * @example 'dev' | 'staging' | 'www' | 'app'\n   */\n  subdomain: z.string().optional(),\n});\n\n/**\n * Type definition for stage configuration.\n *\n * Inferred from StageConfigSchema for type-safe configuration objects.\n */\nexport type StageConfig = z.infer<typeof StageConfigSchema>;\n\n/**\n * Path configuration for project structure.\n *\n * Defines the directory layout and entry points for your Runtime Web application.\n * These paths are used by the build system, development server, and deployment process.\n * All paths are relative to the project root directory.\n *\n * @example\n * ```typescript\n * const paths: PathsConfig = {\n *   srcDir: 'src',\n *   reactEntry: 'src/index.tsx',\n *   outDir: 'out/dist',\n *   cdkDir: 'infrastructure'\n * };\n * ```\n */\nexport const PathsConfigSchema = z.object({\n  /**\n   * Source directory path.\n   *\n   * The root directory containing your application source code.\n   * This is where the build system will look for TypeScript/JavaScript files.\n   *\n   * @default 'src'\n   * @example 'src' | 'app' | 'source'\n   */\n  srcDir: z.string().default('src'),\n\n  /**\n   * React application entry point.\n   *\n   * The main entry file for your React application. This file should export\n   * or call the `runtime()` function to configure your serverless rendering cross-domain application.\n   * Must be a TypeScript (.tsx/.ts) or JavaScript (.jsx/.js) file.\n   *\n   * @default 'src/index.tsx'\n   * @example 'src/index.tsx' | 'src/app.tsx' | 'src/main.tsx'\n   */\n  reactEntry: z.string().default('src/index.tsx'),\n\n  /**\n   * Output directory for build artifacts.\n   *\n   * The directory where compiled JavaScript bundles, type declarations,\n   * and other build artifacts will be written. This directory is typically\n   * added to .gitignore and should not be committed to version control.\n   *\n   * @default 'out/dist'\n   * @example 'out/dist' | 'dist' | 'build'\n   */\n  outDir: z.string().default('out/dist'),\n\n  /**\n   * CDK infrastructure directory (optional).\n   *\n   * The directory containing AWS CDK infrastructure code for deploying\n   * your application. If using the default CDK setup, this can be omitted.\n   * Only needed if you have custom CDK constructs or stacks.\n   *\n   * @default 'cdk'\n   * @example 'cdk' | 'infrastructure' | 'infra'\n   */\n  cdkDir: z.string().default('cdk').optional(),\n});\n\n/**\n * Type definition for path configuration.\n *\n * Inferred from PathsConfigSchema for type-safe configuration objects.\n */\nexport type PathsConfig = z.infer<typeof PathsConfigSchema>;\n\n/**\n * Feature flags configuration.\n *\n * Optional feature toggles for enabling or disabling specific Runtime Web functionality.\n * These flags control which Lambda handlers are deployed and which features are\n * available in your application.\n *\n * @example\n * ```typescript\n * const features: FeaturesConfig = {\n *   enableSeo: true,\n *   enableManifest: true,\n *   enableWarmup: false,\n *   clearCacheOnDeploy: true\n * };\n * ```\n */\nexport const FeaturesConfigSchema = z.object({\n  /**\n   * Enable SEO metadata storage in DynamoDB.\n   *\n   * When enabled, deploys a Lambda handler and DynamoDB table for storing\n   * and retrieving SEO metadata (meta tags, Open Graph data, etc.) for\n   * server-side rendered pages. Useful for dynamic SEO optimization.\n   *\n   * @default false\n   * @example true | false\n   */\n  enableSeo: z.boolean().default(false),\n\n  /**\n   * Enable manifest generation.\n   *\n   * When enabled, deploys a Lambda handler that generates and serves\n   * web app manifest files (manifest.json) for Progressive Web App (PWA)\n   * functionality. Includes icons, theme colors, and app metadata.\n   *\n   * @default true\n   * @example true | false\n   */\n  enableManifest: z.boolean().default(true),\n\n  /**\n   * Enable Lambda warmup function.\n   *\n   * When enabled, deploys a scheduled Lambda function that periodically\n   * invokes your serverless rendering cross-domain handler to keep it warm and reduce cold start latency.\n   * Useful for production environments with strict performance requirements.\n   * Note: This will increase AWS costs due to additional Lambda invocations.\n   *\n   * @default false\n   * @example true | false\n   */\n  enableWarmup: z.boolean().default(false),\n\n  /**\n   * Clear S3 cache directory on deployment.\n   *\n   * When enabled, automatically clears the S3 cache directory (cache/) during\n   * deployment to ensure fresh serverless rendering cross-domain responses after code changes. This prevents\n   * serving stale cached content after updates.\n   *\n   * Disable this option if you want to preserve cache between deployments\n   * (e.g., for faster rollbacks or when cache invalidation is handled separately).\n   *\n   * @default true\n   * @example true | false\n   */\n  clearCacheOnDeploy: z.boolean().default(true),\n});\n\n/**\n * Type definition for features configuration.\n *\n * Inferred from FeaturesConfigSchema for type-safe configuration objects.\n */\nexport type FeaturesConfig = z.infer<typeof FeaturesConfigSchema>;\n\n/**\n * Main Runtime Web CLI configuration schema.\n *\n * The root configuration object for Runtime Web applications. This schema defines\n * all available configuration options for the CLI tool, including project metadata,\n * deployment stages, file paths, infrastructure mode, and feature flags.\n *\n * Configuration files should be named `runtime.config.ts`\n * and placed in the project root directory.\n *\n * @example\n * ```typescript\n * // runtime.config.ts\n * import { RuntimeConfig } from '@worktif/runtime';\n *\n * const config: RuntimeConfig = {\n *   projectName: 'my-app',\n *   stages: [\n *     {\n *       name: 'dev',\n *       awsRegion: 'us-east-1',\n *       awsProfile: 'dev-profile'\n *     },\n *     {\n *       name: 'prod',\n *       awsRegion: 'us-west-2',\n *       domain: 'example.com',\n *       subdomain: 'www'\n *     }\n *   ],\n *   paths: {\n *     srcDir: 'src',\n *     reactEntry: 'src/index.tsx',\n *     outDir: 'out/dist'\n *   },\n *   infraMode: 'cdk',\n *   features: {\n *     enableSeo: true,\n *     enableManifest: true,\n *     enableWarmup: false,\n *     clearCacheOnDeploy: true\n *   }\n * };\n *\n * export default config;\n * ```\n */\nexport const RuntimeConfigSchema = z.object({\n  /**\n   * Project name identifier.\n   *\n   * A unique name for your project. This is used to namespace AWS resources\n   * (CloudFormation stacks, S3 buckets, Lambda functions) and must be unique\n   * within your AWS account. Use lowercase letters, numbers, and hyphens only.\n   *\n   * @example 'my-app' | 'company-website' | 'api-gateway'\n   */\n  projectName: z.string().min(1),\n\n  /**\n   * Deployment stage configurations.\n   *\n   * An array of stage configurations defining different deployment environments.\n   * Each stage represents a separate AWS deployment with its own resources.\n   * At least one stage is required. Common patterns include:\n   * - Single stage: ['dev']\n   * - Two stages: ['dev', 'prod']\n   * - Three stages: ['dev', 'staging', 'prod']\n   *\n   * @example\n   * ```typescript\n   * stages: [\n   *   { name: 'dev', awsRegion: 'us-east-1' },\n   *   { name: 'prod', awsRegion: 'us-west-2', domain: 'example.com' }\n   * ]\n   * ```\n   */\n  stages: z.array(StageConfigSchema).min(1),\n\n  /**\n   * Project path configuration.\n   *\n   * Defines the directory structure and entry points for your application.\n   * These paths are used by the build system, development server, and CLI commands.\n   * All paths are relative to the project root directory.\n   *\n   * @see PathsConfig for detailed path options\n   */\n  paths: PathsConfigSchema,\n\n  /**\n   * Infrastructure mode.\n   *\n   * Determines how AWS infrastructure is managed:\n   * - 'cdk': Use AWS CDK for infrastructure as code (recommended)\n   * - 'auto': Automatic infrastructure management (experimental)\n   *\n   * CDK mode provides full control over AWS resources and is production-ready.\n   * Auto mode is experimental and may have limitations.\n   *\n   * @default 'cdk'\n   * @example 'cdk' | 'auto'\n   */\n  infraMode: z.enum(['cdk', 'auto']).default('cdk'),\n\n  /**\n   * Optional feature flags.\n   *\n   * Enable or disable specific Runtime Web features. When omitted, default values\n   * are used for all features. Use this to control which Lambda handlers are\n   * deployed and which functionality is available in your application.\n   *\n   * @see FeaturesConfig for available feature flags\n   */\n  features: FeaturesConfigSchema.optional(),\n});\n\n/**\n * Type definition for Runtime Web CLI configuration.\n *\n * Inferred from RuntimeConfigSchema for type-safe configuration objects.\n * Use this type when creating configuration files or working with configuration\n * objects in your application code.\n *\n * @example\n * ```typescript\n * import { RuntimeConfig } from '@worktif/runtime';\n *\n * const config: RuntimeConfig = {\n *   projectName: 'my-app',\n *   stages: [{ name: 'dev', awsRegion: 'us-east-1' }],\n *   paths: {\n *     srcDir: 'src',\n *     reactEntry: 'src/index.tsx',\n *     outDir: 'out/dist'\n *   },\n *   infraMode: 'cdk'\n * };\n * ```\n */\nexport type RuntimeConfig = z.infer<typeof RuntimeConfigSchema>;\n\n/**\n * Default configuration values.\n *\n * Provides sensible defaults for all configuration options. These values are used\n * when a configuration file is missing or when specific options are omitted from\n * the user's configuration. The CLI will merge user-provided configuration with\n * these defaults to ensure all required fields are present.\n *\n * Default configuration includes:\n * - Project name: 'runtime-web-app'\n * - Single development stage in us-east-1\n * - Standard directory structure (src/, out/dist/)\n * - CDK infrastructure mode\n * - Manifest enabled, SEO and warmup disabled\n *\n * @example\n * ```typescript\n * import { DEFAULT_CLI_CONFIG } from '@worktif/runtime';\n *\n * // Merge user config with defaults\n * const config = { ...DEFAULT_CLI_CONFIG, ...userConfig };\n * ```\n */\nexport const DEFAULT_CLI_CONFIG: RuntimeConfig = {\n  projectName: 'runtime-web-app',\n  stages: [\n    {\n      name: 'dev',\n      awsRegion: 'us-east-1',\n    },\n  ],\n  paths: {\n    srcDir: 'src',\n    reactEntry: 'src/index.tsx',\n    outDir: 'out/dist',\n    cdkDir: 'cdk',\n  },\n  infraMode: 'cdk',\n  features: {\n    enableSeo: false,\n    enableManifest: true,\n    enableWarmup: false,\n    clearCacheOnDeploy: true,\n  },\n};\n\n", "/*\n * Elastic License 2.0\n * Copyright (C) 2025\u2013present Raman Marozau, Work Target Insight Function. All rights reserved.\n * Contact: raman@worktif.com\n *\n * This file is part of the Licensed Work: worktif.runtime.cdk <worktif_runtime_cdk>.\n * Use of this software is governed by the Elastic License 2.0; see the LICENSE file\n * or https://www.elastic.co/licensing/elastic-license for details.\n *\n * Re-licensing notice:\n *   This file was previously distributed under the Business Source License 1.1 (BUSL-1.1).\n *   As of 2025-09-22, it is re-licensed under Elastic License 2.0.\n *\n * SPDX-License-Identifier: Elastic-2.0\n */\n\n/**\n * Enum representing the possible deployment stacks for the application.\n *\n * @enum {string}\n * @readonly\n * @property {string} RuntimeWebStack Represents the stack value 'runtime-web-stack'.\n */\nexport enum DeployStacks {\n  RuntimeWebStack = 'runtime-web-stack',\n}\n\n/**\n * Enum representing DynamoDB table names.\n *\n * This enum contains constants that map to the names of tables used in\n * DynamoDB for the application. Each constant represents a string\n * identifying the table's name in the database.\n */\nexport enum DynamoDbTables {\n  SeoEngineDynamoDbEntity = 'runtime_web_seo_engine',\n}\n\n\n/**\n * Enumeration representing S3 bucket names. This enum is used to define\n * and manage the identifiers for specific S3 buckets within the application.\n *\n * Members:\n * - StaticS3Bucket: Represents a static S3 bucket identifier.\n */\nexport enum S3Buckets {\n  StaticS3Bucket = 'runtime_web_static',\n}\n\n\n/**\n * Represents the stages for the API Gateway in the application.\n *\n * This enumeration holds different stage values linked to the API Gateway configuration.\n * These stages are used to define and identify various deployment environments or stages\n * of the API Gateway, which helps in routing requests appropriately within the system.\n *\n * Enumeration Members:\n * - `RuntimeApiGatewayStage`: Refers to the stage labeled as 'runtime_web_api_gateway_stage'.\n *\n * Designed to manage and streamline communication with API Gateway by leveraging specific stage identifiers.\n */\nexport enum ApiGatewayStages {\n  RuntimeWebApiGatewayStage = 'runtime_web_api_gateway_stage',\n}\n\n/**\n * Enumeration representing types of CloudFront distributions.\n *\n * The enum contains the possible values that can be used to represent\n * CloudFront distribution types. This can be used, for example, to\n * specify or identify distribution configurations or categories\n * within the CloudFront service.\n *\n * Members:\n * - CloudFrontDistribution: Represents a standard CloudFront distribution type.\n */\nexport enum CloudFrontDistributions {\n  CloudFrontDistribution = 'runtime_web_distribution',\n}\n\n\n/**\n * Enumeration representing various Lambda functions utilized within the application.\n *\n * This enum is used to reference specific Lambda functions by their identifier strings.\n *\n * Enum members:\n * - `RuntimeHandlerLambda`: Represents the handler for serverless rendering cross-domain operations.\n * - `SsrSeoLambda`: Represents the Lambda handling SEO-related serverless rendering cross-domain tasks.\n * - `SsrManifestLambda`: Represents the Lambda responsible for managing serverless rendering cross-domain manifests.\n */\nexport enum LambdaFunctions {\n  RuntimeWebHandlerLambda = 'lambdaRuntimeWebHandler',\n  RuntimeWebSeoLambda = 'lambdaRuntimeWebSeoHandler',\n  RuntimeWebWarmupLambda = 'lambdaRuntimeWebWarmupHandler',\n  RuntimeWebManifestLambda = 'lambdaRuntimeWebManifestHandler',\n}\n\n\n/**\n * Enum representing the execution role used for React serverless Lambda functions.\n *\n * The `RuntimeLambdaExecutionRole` enum is utilized to define and represent\n * the specific execution role required by a React serverless Lambda function\n * to interact with AWS services securely.\n *\n * This enum ensures consistent usage of the role name across the application\n * when working with serverless Lambda functions within a React framework.\n *\n * Enum members:\n * - `RuntimeWebLambdaExecutionRole`: Represents the execution role identifier\n *   for Runtime Lambda functions.\n */\nexport enum IamExecutionRoles {\n  RuntimeLambdaExecutionRole = 'runtime_web_lambda_execution_role',\n}\n\n/**\n * Enum representing the API Gateway Execution Router.\n *\n * This enum provides route identifiers for different API Gateway execution routers.\n *\n * Enum Members:\n * - RuntimeWebApiGatewayExecutionRouter: Represents the execution router for Runtime Web API Gateway.\n */\nexport enum ApiGatewayExecutionRouters {\n  RuntimeWebApiGatewayExecutionRouter = 'runtime_web_api_gateway_execution_router',\n}\n\n\n"],
  "mappings": "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",
  "names": ["require_legacy", "__commonJSMin", "exports", "require_utils", "__commonJSMin", "exports", "require_utils_functions", "__commonJSMin", "exports", "utils_1", "getReasonPhrase", "statusCode", "result", "getStatusCode", "reasonPhrase", "require_status_codes", "__commonJSMin", "exports", "StatusCodes", "require_reason_phrases", "__commonJSMin", "exports", "ReasonPhrases", "require_cjs", "__commonJSMin", "exports", "__assign", "t", "s", "i", "p", "__createBinding", "o", "m", "k", "k2", "__exportStar", "__importDefault", "mod", "legacy_1", "utils_functions_1", "utils_functions_2", "status_codes_1", "reason_phrases_1", "index_exports", "__export", "ApiGatewayExecutionRouters", "ApiGatewayStages", "AwsRegionSchema", "BrowserPipeline", "CloudFrontDistributions", "DEFAULT_CLI_CONFIG", "DeployStacks", "DynamoDbTables", "EnginesBrowserFramework", "ErrorBoundary", "ErrorBoundaryNotFound", "FeaturesConfigSchema", "IamExecutionRoles", "LambdaFunctions", "PathsConfigSchema", "RuntimeAppServer", "RuntimeConfigSchema", "RuntimeHeadManager", "RuntimeRouter", "RuntimeRouterProvider", "S3Buckets", "StageConfigSchema", "createRouteLoader", "createSeoRetriever", "executeRuntimeAsync", "fetchSeoMetadata", "getDefaultSeoMeta", "injectFlow", "intersection", "isBrowser", "isLambdaRuntime", "isValidServiceName", "mergeLoaderResults", "routePath", "routerContext", "runtime", "runtimeRouter", "runtimeThreads", "useRuntimeData", "useRuntimeSeoMeta", "__toCommonJS", "React", "import_react", "import_react_router", "useRuntimeData", "loaderData", "useRuntimeSeoMeta", "constructSeoApiUrl", "route", "apiBaseUrl", "fetchSeoMetadataFromApi", "url", "response", "data", "adaptBackendSeoToFrontend", "error", "backend", "createSeoRetriever", "routePath", "ctx", "fetchSeoMetadata", "getDefaultSeoMeta", "error", "resolvedPath", "key", "value", "fetchSeoMetadataFromApi", "RESERVED_INTERNAL_KEY", "createRouteLoader", "routePath", "userRetrievers", "args", "params", "request", "searchParams", "context", "internalRetrievers", "createSeoRetriever", "userRetrieversWithMetadata", "retriever", "index", "allRetrievers", "results", "executeRuntimeAsync", "mergeLoaderResults", "retrievers", "promises", "loaderResult", "result", "isInternal", "name", "data", "_", "rest", "logRetrieverFailure", "reason", "retrieverName", "error", "errorMessage", "stackTrace", "logPrefix", "React", "import_react", "import_react_router", "RuntimeRouterProvider", "router", "currentRouter", "setCurrentRouter", "React", "import_react", "routePath", "path", "injectFlow", "children", "router", "child", "intersection", "arr1", "arr2", "set1", "set2", "result", "item", "RuntimeRouter", "router", "defaults", "transformedRoutes", "defaultsKeys", "route", "index", "routerKeys", "intersected", "intersection", "key", "routes", "path", "runtimeAsync", "children", "routeProps", "routePathname", "routePath", "loader", "createRouteLoader", "transformedChildren", "result", "id", "runtimeRouter", "options", "ErrorBoundary", "props", "error", "errorInfo", "handlerError", "prevState", "newTimer", "routePath", "styles", "e", "ErrorBoundaryNotFound", "redirectTimer", "setRedirectTimer", "countdown", "prev", "import_react", "import_react_router", "headManagerInstanceCount", "RuntimeHeadManager", "location", "matches", "isMountedRef", "seoMeta", "updateMetaTag", "updateMetaProperty", "updateMetaName", "updateLinkTag", "updateJsonLd", "error", "name", "content", "meta", "escapedContent", "escapeHtml", "property", "rel", "href", "link", "escapedHref", "jsonLd", "script", "jsonString", "text", "div", "React", "import_react", "RuntimeAppServer", "children", "mounted", "setMounted", "fadeIn", "setFadeIn", "timeout", "runtime_app_server_default", "import_http_status_codes", "isBrowser", "findMatchingRoute", "route", "pathname", "matchDynamicRoute", "extractParams", "child", "match", "routePath", "routeSegments", "pathnameSegments", "segment", "index", "params", "routerContext", "location", "router", "matches", "React", "import_react_router", "import_client", "isLambdaRuntime", "key", "EMPTY_STRING", "runtimeThreads", "runtime", "runtimeThreadsInstance", "RuntimeRouter", "isLambdaRuntime", "renderReactApp", "error", "appOptions", "isBrowser", "rootElement", "rootRuntime", "stage", "pathname", "location", "context", "routerContext", "routerBrowser", "runtime_app_server_default", "errorInfo", "root", "AppRouted", "React", "import_client", "import_react_router", "BrowserPipeline", "config", "context", "browserRouter", "appElement", "routerProvider", "error", "routes", "container", "baseUrl", "stage", "isValidServiceName", "serviceName", "EnginesBrowserFramework", "import_zod", "AWS_REGIONS", "AwsRegionSchema", "StageConfigSchema", "PathsConfigSchema", "FeaturesConfigSchema", "RuntimeConfigSchema", "DEFAULT_CLI_CONFIG", "DeployStacks", "DynamoDbTables", "S3Buckets", "ApiGatewayStages", "CloudFrontDistributions", "LambdaFunctions", "IamExecutionRoles", "ApiGatewayExecutionRouters"]
}

@@ -1,3 +1,4 @@
1
1
  export * from './runtime-core';
2
2
  export * from './runtime-web';
3
3
  export * from './runtime.types';
4
+ export type { RuntimeConfig } from '../utils/types/runtime.config';
@@ -1,3 +1,4 @@
1
1
  export * from './runtime-core';
2
2
  export * from './runtime-web';
3
3
  export * from './runtime.types';
4
+ export type { RuntimeConfig } from '../utils/types/runtime.config';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@worktif/runtime",
3
- "version": "0.3.0-edge.38",
3
+ "version": "0.3.0-edge.39",
4
4
  "description": "Serverless web framework running on AWS Lambda with support for server-side rendering, caching, and CI/CD.",
5
5
  "repository": "git@bitbucket.org:worktif/runtime-target.git",
6
6
  "author": "Raman Marozau <raman@worktif.com>",