@t-req/core 0.1.0 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/README.md +158 -15
  2. package/dist/client.d.ts +0 -3
  3. package/dist/client.d.ts.map +1 -1
  4. package/dist/config/engine-options.d.ts +48 -0
  5. package/dist/config/engine-options.d.ts.map +1 -0
  6. package/dist/config/index.d.ts +7 -3
  7. package/dist/config/index.d.ts.map +1 -1
  8. package/dist/config/index.js +5 -2
  9. package/dist/config/index.js.map +10 -5
  10. package/dist/config/jsonc.d.ts +18 -0
  11. package/dist/config/jsonc.d.ts.map +1 -0
  12. package/dist/config/load.d.ts +13 -2
  13. package/dist/config/load.d.ts.map +1 -1
  14. package/dist/config/merge.d.ts +31 -5
  15. package/dist/config/merge.d.ts.map +1 -1
  16. package/dist/config/resolve.d.ts +59 -0
  17. package/dist/config/resolve.d.ts.map +1 -0
  18. package/dist/config/substitution.d.ts +25 -0
  19. package/dist/config/substitution.d.ts.map +1 -0
  20. package/dist/config/types.d.ts +60 -6
  21. package/dist/config/types.d.ts.map +1 -1
  22. package/dist/cookies/persistence.d.ts +48 -0
  23. package/dist/cookies/persistence.d.ts.map +1 -0
  24. package/dist/cookies/persistence.js +4 -0
  25. package/dist/cookies/persistence.js.map +10 -0
  26. package/dist/cookies.js +5 -5
  27. package/dist/cookies.js.map +2 -2
  28. package/dist/engine/engine.d.ts +0 -4
  29. package/dist/engine/engine.d.ts.map +1 -1
  30. package/dist/engine/index.js +4 -4
  31. package/dist/engine/index.js.map +4 -4
  32. package/dist/index.d.ts +1 -0
  33. package/dist/index.d.ts.map +1 -1
  34. package/dist/index.js +4 -4
  35. package/dist/index.js.map +8 -6
  36. package/dist/interpolate.d.ts.map +1 -1
  37. package/dist/resolver/command.d.ts +19 -0
  38. package/dist/resolver/command.d.ts.map +1 -0
  39. package/dist/resolver/index.d.ts +2 -0
  40. package/dist/resolver/index.d.ts.map +1 -0
  41. package/dist/resolver/index.js +5 -0
  42. package/dist/resolver/index.js.map +10 -0
  43. package/dist/runtime/index.js +2 -2
  44. package/dist/runtime/index.js.map +2 -2
  45. package/dist/server-client.d.ts +50 -0
  46. package/dist/server-client.d.ts.map +1 -0
  47. package/dist/server-metadata.d.ts +13 -0
  48. package/dist/server-metadata.d.ts.map +1 -0
  49. package/dist/types.d.ts +41 -0
  50. package/dist/types.d.ts.map +1 -1
  51. package/package.json +13 -4
@@ -16,10 +16,6 @@ export type EngineRunOptions = {
16
16
  followRedirects?: boolean;
17
17
  validateSSL?: boolean;
18
18
  proxy?: string;
19
- /**
20
- * Base path for resolving file references when running from string content.
21
- * When running from file, this is derived from the .http file directory.
22
- */
23
19
  basePath?: string;
24
20
  };
25
21
  export type Engine = {
@@ -1 +1 @@
1
- {"version":3,"file":"engine.d.ts","sourceRoot":"","sources":["../../src/engine/engine.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,EAAmB,MAAM,WAAW,CAAC;AAEnD,OAAO,KAAK,EAAE,WAAW,EAAe,SAAS,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC3F,OAAO,KAAK,EAA6C,QAAQ,EAAE,MAAM,UAAU,CAAC;AAGpF,MAAM,MAAM,YAAY,GAAG;IACzB,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,EAAE,CAAC,EAAE,EAAE,CAAC;IACR,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACrC,OAAO,CAAC,EAAE,SAAS,CAAC;IACpB,cAAc,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACzC,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACpC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf;;;OAGG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,MAAM,GAAG;IACnB,WAAW,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,UAAU,CAAC,OAAO,KAAK,CAAC,CAAC;IAC5D,SAAS,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,gBAAgB,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC/E,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,gBAAgB,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC;CAC1E,CAAC;AA2DF,wBAAgB,YAAY,CAAC,MAAM,GAAE,YAAiB,GAAG,MAAM,CA+I9D"}
1
+ {"version":3,"file":"engine.d.ts","sourceRoot":"","sources":["../../src/engine/engine.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,EAAmB,MAAM,WAAW,CAAC;AAEnD,OAAO,KAAK,EAAE,WAAW,EAAe,SAAS,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC3F,OAAO,KAAK,EAA6C,QAAQ,EAAE,MAAM,UAAU,CAAC;AAGpF,MAAM,MAAM,YAAY,GAAG;IACzB,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,EAAE,CAAC,EAAE,EAAE,CAAC;IACR,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IACrC,OAAO,CAAC,EAAE,SAAS,CAAC;IACpB,cAAc,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACzC,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACpC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,WAAW,CAAC;IACrB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,MAAM,GAAG;IACnB,WAAW,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,UAAU,CAAC,OAAO,KAAK,CAAC,CAAC;IAC5D,SAAS,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,gBAAgB,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC/E,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,gBAAgB,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC;CAC1E,CAAC;AA2DF,wBAAgB,YAAY,CAAC,MAAM,GAAE,YAAiB,GAAG,MAAM,CA+I9D"}
@@ -1,6 +1,6 @@
1
- function y(G){throw Error(`${G} is not supported by this transport. Provide a transport that supports it.`)}function x(G=fetch){return{capabilities:{proxy:!1,validateSSL:!1},async fetch(K,Q,Z){if(Z.proxy)y("proxy");if(Z.validateSSL===!1)y("validateSSL=false");return await G(K,Q)}}}function s(){return typeof globalThis.Bun<"u"}function F(){if(!s())return x(fetch);return{capabilities:{proxy:!0,validateSSL:!0},async fetch(G,K,Q){let Z={...K??{}};if(Q.proxy!==void 0)Z.proxy=Q.proxy;if(Q.validateSSL===!1)Z.tls={rejectUnauthorized:!1};return await fetch(G,Z)}}}function N(G){let K={...G},Q={when(Z,$){if(Z)K={...K,...$};return Q},ifDefined(Z,$){if($!==void 0)K={...K,[Z]:$};return Q},build(){return K}};return Q}function r(G,K){return K!==void 0&&!["GET","HEAD"].includes(G.toUpperCase())}function i(G,K){let Q=r(G.method,G.body)&&G.body!==void 0;return N({method:G.method,redirect:K.followRedirects?"follow":"manual",signal:K.signal}).ifDefined("headers",G.headers).ifDefined("body",Q?G.body:void 0).build()}function a(G){if(G.provided)return{signal:G.provided,isInternalTimeout:!1,cleanup:()=>{}};let K=new AbortController,Q=setTimeout(()=>K.abort(),G.timeout);return{signal:K.signal,isInternalTimeout:!0,cleanup:()=>clearTimeout(Q)}}function o(G,K){if(G instanceof Error&&G.name==="AbortError"){if(K.isInternalTimeout)return Error(`Request timeout after ${K.timeout}ms`)}return G instanceof Error?G:Error(String(G))}async function P(G,K,Q){let Z=K.timeout??30000,$=N({timeout:Z}).ifDefined("provided",K.signal).build(),{signal:Y,isInternalTimeout:J,cleanup:H}=a($),j=N({followRedirects:K.followRedirects??!0,signal:Y}).build(),w=i(G,j);try{let D=N({}).ifDefined("proxy",K.proxy).ifDefined("validateSSL",K.validateSSL).build();return await Q.fetch(G.url,w,D)}catch(D){throw o(D,{timeout:Z,isInternalTimeout:J})}finally{H()}}var t={".json":"application/json",".xml":"application/xml",".txt":"text/plain",".html":"text/html",".htm":"text/html",".css":"text/css",".js":"application/javascript",".mjs":"application/javascript",".ts":"application/typescript",".csv":"text/csv",".md":"text/markdown",".yaml":"text/yaml",".yml":"text/yaml",".svg":"image/svg+xml",".jpg":"image/jpeg",".jpeg":"image/jpeg",".png":"image/png",".gif":"image/gif",".webp":"image/webp",".ico":"image/x-icon",".bmp":"image/bmp",".tiff":"image/tiff",".tif":"image/tiff",".pdf":"application/pdf",".doc":"application/msword",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".xls":"application/vnd.ms-excel",".xlsx":"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",".ppt":"application/vnd.ms-powerpoint",".pptx":"application/vnd.openxmlformats-officedocument.presentationml.presentation",".zip":"application/zip",".gz":"application/gzip",".tar":"application/x-tar",".rar":"application/vnd.rar",".7z":"application/x-7z-compressed",".mp3":"audio/mpeg",".wav":"audio/wav",".ogg":"audio/ogg",".m4a":"audio/mp4",".mp4":"video/mp4",".webm":"video/webm",".avi":"video/x-msvideo",".mov":"video/quicktime",".wasm":"application/wasm",".bin":"application/octet-stream",".exe":"application/octet-stream",".dll":"application/octet-stream",".so":"application/octet-stream",".dylib":"application/octet-stream"},e=new Set(["application/json","application/xml","application/javascript","application/typescript","text/plain","text/html","text/css","text/csv","text/xml","text/markdown","text/yaml","image/svg+xml"]);function GG(G){let K=YG(G).toLowerCase();return t[K]??"application/octet-stream"}function KG(G){if(G.startsWith("text/"))return!1;if(e.has(G))return!1;return!0}function T(G){return G.includes("\\")?"\\":"/"}function E(G){return G.split(/[\\/]+/).filter(Boolean)}function QG(G){if(G.startsWith("/")||G.startsWith("\\"))return!0;if(/^[A-Za-z]:[\\/]/.test(G))return!0;if(G.startsWith("\\\\"))return!0;return!1}function L(G,K){let Q=[];for(let Z of K){if(!Z||Z===".")continue;if(Z===".."){Q.pop();continue}Q.push(Z)}return(G==="\\"?"\\":"/")+Q.join(G)}function ZG(G,K){let Q=T(G),Z=/^[A-Za-z]:$/.test(G),Y=G.match(/^([A-Za-z]:)[\\/]?/)?.[1],J=E(G),H=E(K);if(Y){let j=L(Q,[...J.slice(1),...H]);return`${Y}${j}`}if(Z){let j=L(Q,H);return`${G}${j}`}return L(Q,[...J,...H])}function $G(G){if(G==="")return"/";let K=T(G),Z=G.match(/^([A-Za-z]:)[\\/]?/)?.[1],$=E(G);if(Z){let Y=L(K,$.slice(1));return`${Z}${Y}`}return L(K,$)}function YG(G){let K=XG(G),Q=K.lastIndexOf(".");if(Q<=0)return"";return K.slice(Q)}function XG(G){let K=G.split(/[\\/]/);return K[K.length-1]??""}function HG(G,K){if(QG(G))throw Error(`Absolute paths not allowed: ${G}`);let Q=ZG(K,G),Z=$G(K),$=T(Z);if(Q!==Z&&!Q.startsWith(Z+$))throw Error(`Path escapes base directory: ${G}`);return Q}async function B(G,K={}){let Q=K.basePath??K.io?.cwd()??globalThis.process?.cwd?.()??".",Z=HG(G,Q),$=GG(G),Y=KG($),J;if(K.io){if(!await K.io.exists(Z))throw Error(`File not found: ${G}`);J=Y?await K.io.readBinary(Z):await K.io.readText(Z)}else if(typeof globalThis.Bun<"u"){let j=globalThis.Bun.file(Z);if(!await j.exists())throw Error(`File not found: ${G}`);J=Y?await j.arrayBuffer():await j.text()}else throw Error("No IO adapter provided. Provide `options.io` (Node/Bun/Tauri) to load file bodies.");return{content:J,isBinary:Y,mimeType:$}}function f(G){return G.some((K)=>K.isFile)}async function v(G,K={}){let Q=new FormData,Z=K.basePath??K.io?.cwd()??globalThis.process?.cwd?.()??".";for(let $ of G)if($.isFile&&$.path){let Y=await B($.path,K.io?{basePath:Z,io:K.io}:{basePath:Z}),J=$.filename??K.io?.path.basename($.path)??JG($.path),H=new Blob([Y.content],{type:Y.mimeType});Q.append($.name,H,J)}else Q.append($.name,$.value);return Q}function JG(G){let K=G.split(/[\\/]/);return K[K.length-1]??""}function b(G){let K=new URLSearchParams;for(let Q of G){if(Q.isFile)continue;K.append(Q.name,Q.value)}return K}var m=/\{\{([^}]+)\}\}/g,c=/^\$(\w+)\(([^)]*)\)$/;function h(G){if(!G.trim())return[];return G.split(",").map((K)=>K.trim())}function u(G,K){let Q=K.split("."),Z=G;for(let $ of Q){if(Z===null||Z===void 0)return;if(typeof Z!=="object")return;Z=Z[$]}return Z}function jG(G,K,Q={}){let{resolvers:Z={},undefinedBehavior:$="throw"}=Q;return G.replace(m,(Y,J)=>{let H=J.trim(),j=H.match(c);if(j){let[,D,U]=j,X=Z[`$${D}`];if(X){let W=h(U??""),C=X(...W);if(C instanceof Promise)throw Error(`Resolver $${D} returned a Promise. Use createInterpolator() for async resolvers.`);return String(C)}if($==="throw")throw Error(`Unknown resolver: $${D}`);return $==="keep"?Y:""}let w=u(K,H);if(w===void 0){if($==="throw")throw Error(`Undefined variable: ${H}`);return $==="keep"?Y:""}return String(w)})}async function UG(G,K,Q={}){let{resolvers:Z={},undefinedBehavior:$="throw"}=Q,Y=[],J=new RegExp(m.source,"g"),H=J.exec(G);while(H!==null){let U=H[1];if(U===void 0){H=J.exec(G);continue}Y.push({match:H[0],expression:U,index:H.index}),H=J.exec(G)}if(Y.length===0)return G;let j=await Promise.all(Y.map(async({match:U,expression:X})=>{let W=X.trim(),C=W.match(c);if(C){let[,_,z]=C,A=Z[`$${_}`];if(A){let I=h(z??""),S=await A(...I);return String(S)}if($==="throw")throw Error(`Unknown resolver: $${_}`);return $==="keep"?U:""}let V=u(K,W);if(V===void 0){if($==="throw")throw Error(`Undefined variable: ${W}`);return $==="keep"?U:""}return String(V)})),w="",D=0;for(let U=0;U<Y.length;U++){let X=Y[U];if(!X)continue;let{match:W,index:C}=X;w+=G.slice(D,C),w+=j[U],D=C+W.length}return w+=G.slice(D),w}function g(G,K,Q){if(typeof G==="string")return jG(G,K,Q);if(Array.isArray(G))return G.map((Z)=>g(Z,K,Q));if(G!==null&&typeof G==="object"){let Z={};for(let[$,Y]of Object.entries(G))Z[$]=g(Y,K,Q);return Z}return G}async function k(G,K,Q){if(typeof G==="string")return await UG(G,K,Q);if(Array.isArray(G))return await Promise.all(G.map((Z)=>k(Z,K,Q)));if(G!==null&&typeof G==="object"){let Z={},$=Object.entries(G),Y=await Promise.all($.map(async([J,H])=>[J,await k(H,K,Q)]));for(let[J,H]of Y)Z[J]=H;return Z}return G}function gG(G,K,Q={}){return g(G,K,Q)}function d(G={}){return{async interpolate(K,Q){return k(K,Q,G)}}}var p=/^([^=]+?)\s*=\s*(.*)$/;function DG(G,K){if(K&&!K.includes("form-data")&&!K.includes("x-www-form-urlencoded"))return!1;let Q=G.split(/\r?\n/).filter((Z)=>Z.trim());if(Q.length===0)return!1;if(Q.length===1&&Q[0]?.includes("&"))return!1;return Q.every((Z)=>p.test(Z))}function WG(G){let K=[],Q=G.split(/\r?\n/).filter((Z)=>Z.trim());for(let Z of Q){let $=Z.match(p);if(!$)continue;let Y=$[1],J=$[2];if(!Y)continue;let H=Y.trim(),j=(J??"").trim();if(j.startsWith("@./")||j.startsWith("@{{")){j=j.slice(1);let D=j,U,X=j.indexOf(" | ");if(X!==-1)D=j.slice(0,X).trim(),U=j.slice(X+3).trim();K.push(N({name:H,value:"",isFile:!0,path:D}).ifDefined("filename",U).build())}else K.push({name:H,value:j,isFile:!1})}return K}function M(G){let K=[],Q=G.split(/\r?\n/),Z=[],$={lines:[]};for(let Y of Q){let J=Y.match(/^###\s*(.*)$/);if(J){if($.lines.length>0||Z.length===0)Z.push($);let H=J[1]?.trim();$=N({lines:[]}).ifDefined("name",H||void 0).build()}else $.lines.push(Y)}Z.push($);for(let Y of Z){if(Y.lines.length===0&&!Y.name)continue;let J=Y.lines.join(`
2
- `),H=zG(J,Y.name);if(H)K.push(H)}return K}function zG(G,K){let Q=G.split(/\r?\n/),Z={},$=K,Y="",J="",H={},j,w,D,U=!1,X=[],W=!1;for(let V=0;V<Q.length;V++){let _=Q[V];if(_===void 0)continue;let z=_.trim();if(!W&&z==="")continue;if(!W&&(z.startsWith("#")||z.startsWith("//"))){let I=z.replace(/^(#|\/\/)\s*/,"").match(/^@(\w+)\s*(.*)?$/);if(I){let[,S,R]=I;if(S==="name")$=R?.trim()||$;else if(S)Z[S]=R?.trim()||""}continue}if(!W){let A=z.match(/^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\s+(\S+)(\s+HTTP\/[\d.]+)?$/i);if(A){let S=A[1],R=A[2];if(!S||!R)continue;Y=S.toUpperCase(),J=R,W=!0;continue}let I=z.match(/^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\s+(.+)$/i);if(I){let S=I[1],R=I[2];if(!S||!R)continue;Y=S.toUpperCase(),J=R.trim(),W=!0;continue}continue}if(U)X.push(_);else if(z==="")U=!0;else{let A=_.match(/^([^:]+):\s*(.*)$/);if(A){let I=A[1];if(!I)continue;let S=A[2]??"";H[I.trim()]=S.trim()}}}if(!Y||!J)return null;if(X.length>0){while(X.length>0&&X[X.length-1]?.trim()==="")X.pop();if(X.length===1){let V=X[0]?.trim().match(/^<\s+(.+)$/);if(V){let _=V[1];if(_)w={path:_}}else if(X[0]?.trim())j=X[0]}else if(X.length>0)j=X.join(`
3
- `)}let C=H["Content-Type"]||H["content-type"];if(j&&DG(j,C))D=WG(j),j=void 0;return N({method:Y,url:J,headers:H,raw:G,meta:Z}).ifDefined("name",$).ifDefined("body",j).ifDefined("bodyFile",w).ifDefined("formData",D).build()}async function yG(G){return await q(G)}async function q(G,K){if(K){let Q=await K.readText(G);return M(Q)}if(typeof globalThis.Bun<"u"){let $=await globalThis.Bun.file(G).text();return M($)}throw Error("No IO adapter provided. Use parseFileWithIO(path, io) in this runtime.")}function O(G,K){G?.(K)}function l(G,K){let Q=G[0];if(!Q)throw Error(K);return Q}function _G(G){let K=Math.max(G.lastIndexOf("/"),G.lastIndexOf("\\"));if(K===-1)return".";return K===0?G.slice(0,1):G.slice(0,K)}function wG(G){if(G.startsWith("/")||G.startsWith("\\"))return!0;if(/^[A-Za-z]:[\\/]/.test(G))return!0;if(G.startsWith("\\\\"))return!0;return!1}function VG(G,K){if(!G)return K;if(!K)return G;let Q=G.includes("\\")?"\\":"/",Z=G.endsWith("/")||G.endsWith("\\")?G.slice(0,-1):G,$=K.startsWith("/")||K.startsWith("\\")?K.slice(1):K;return`${Z}${Q}${$}`}function CG(G,K){if(K)return K.path.dirname(K.path.resolve(G));let Q=globalThis.process?.cwd?.()??".",Z=wG(G)?G:VG(Q,G);return _G(Z)}function AG(G,K){if(!K)return G;let Q=G.Cookie||G.cookie||"";return{...G,Cookie:Q?`${Q}; ${K}`:K}}function NG(G={}){let K=G.transport??F(),Q=G.io,Z=G.cookieStore,$=G.onEvent,Y=G.headerDefaults,J=d({resolvers:G.resolvers??{}});async function H(D,U){O($,{type:"parseStarted",source:"string"});let X=M(D);O($,{type:"parseFinished",source:"string",requestCount:X.length});let W=l(X,"No valid requests found in provided content.");O($,{type:"interpolateStarted"});let C={...U.variables??{}},V=await J.interpolate(W,C);O($,{type:"interpolateFinished"}),O($,{type:"compileStarted"});let _=U.basePath??Q?.cwd()??globalThis.process?.cwd?.()??".",{executeRequest:z}=await n(V,N({basePath:_}).ifDefined("io",Q).ifDefined("headerDefaults",Y).build());return O($,{type:"compileFinished"}),{executeRequest:z,baseUrl:V.url}}async function j(D,U){O($,{type:"parseStarted",source:"file"});let X=await q(D,Q);O($,{type:"parseFinished",source:"file",requestCount:X.length});let W=l(X,`No valid requests found in file: ${D}`);O($,{type:"interpolateStarted"});let C={...U.variables??{}},V=await J.interpolate(W,C);O($,{type:"interpolateFinished"}),O($,{type:"compileStarted"});let _=CG(D,Q),{executeRequest:z}=await n(V,N({basePath:_}).ifDefined("io",Q).ifDefined("headerDefaults",Y).build());return O($,{type:"compileFinished"}),{executeRequest:z,baseUrl:V.url}}async function w(D,U,X){let W=D.headers??{},C=Z?await Z.getCookieHeader(U):void 0,V=Z?AG(W,C):W,_={...D,headers:V};O($,{type:"fetchStarted",method:_.method,url:U});try{let z=N({}).ifDefined("timeout",X.timeoutMs).ifDefined("signal",X.signal).ifDefined("followRedirects",X.followRedirects).ifDefined("validateSSL",X.validateSSL).ifDefined("proxy",X.proxy).build(),A=await P(_,z,K);if(O($,{type:"fetchFinished",method:_.method,url:U,status:A.status}),Z)await Z.setFromResponse(U,A);return A}catch(z){throw O($,{type:"error",stage:"fetch",message:z instanceof Error?z.message:String(z)}),z}}return{parseString:M,async runString(D,U={}){let{executeRequest:X,baseUrl:W}=await H(D,U);return await w(X,W,U)},async runFile(D,U={}){let{executeRequest:X,baseUrl:W}=await j(D,U);return await w(X,W,U)}}}async function n(G,K){let Q={...K.headerDefaults??{},...G.headers??{}},Z=G.body;if(G.bodyFile){let Y=await B(G.bodyFile.path,N({basePath:K.basePath}).ifDefined("io",K.io).build());if(Z=Y.content,!Q["Content-Type"]&&!Q["content-type"])Q["Content-Type"]=Y.mimeType}else if(G.formData&&G.formData.length>0){if(f(G.formData))Z=await v(G.formData,N({basePath:K.basePath}).ifDefined("io",K.io).build()),delete Q["Content-Type"],delete Q["content-type"];else if(Z=b(G.formData),!Q["Content-Type"]&&!Q["content-type"])Q["Content-Type"]="application/x-www-form-urlencoded"}return{executeRequest:{method:G.method,url:G.url,headers:Q,...Z!==void 0?{body:Z}:{}}}}export{NG as createEngine};
1
+ import{createRequire as r}from"node:module";var zg=r(import.meta.url);function B(g){throw Error(`${g} is not supported by this transport. Provide a transport that supports it.`)}function P(g=fetch){return{capabilities:{proxy:!1,validateSSL:!1},async fetch(w,E,R){if(R.proxy)B("proxy");if(R.validateSSL===!1)B("validateSSL=false");return await g(w,E)}}}function i(){return typeof globalThis.Bun<"u"}function N(){if(!i())return P(fetch);return{capabilities:{proxy:!0,validateSSL:!0},async fetch(g,w,E){let R={...w??{}};if(E.proxy!==void 0)R.proxy=E.proxy;if(E.validateSSL===!1)R.tls={rejectUnauthorized:!1};return await fetch(g,R)}}}function Q(g){let w={...g},E={when(R,D){if(R)w={...w,...D};return E},ifDefined(R,D){if(D!==void 0)w={...w,[R]:D};return E},build(){return w}};return E}function p(g,w){return w!==void 0&&!["GET","HEAD"].includes(g.toUpperCase())}function t(g,w){let E=p(g.method,g.body)&&g.body!==void 0;return Q({method:g.method,redirect:w.followRedirects?"follow":"manual",signal:w.signal}).ifDefined("headers",g.headers).ifDefined("body",E?g.body:void 0).build()}function l(g){if(g.provided)return{signal:g.provided,isInternalTimeout:!1,cleanup:()=>{}};let w=new AbortController,E=setTimeout(()=>w.abort(),g.timeout);return{signal:w.signal,isInternalTimeout:!0,cleanup:()=>clearTimeout(E)}}function a(g,w){if(g instanceof Error&&g.name==="AbortError"){if(w.isInternalTimeout)return Error(`Request timeout after ${w.timeout}ms`)}return g instanceof Error?g:Error(String(g))}async function m(g,w,E){let R=w.timeout??30000,D=Q({timeout:R}).ifDefined("provided",w.signal).build(),{signal:S,isInternalTimeout:W,cleanup:C}=l(D),O=Q({followRedirects:w.followRedirects??!0,signal:S}).build(),G=t(g,O);try{let F=Q({}).ifDefined("proxy",w.proxy).ifDefined("validateSSL",w.validateSSL).build();return await E.fetch(g.url,G,F)}catch(F){throw a(F,{timeout:R,isInternalTimeout:W})}finally{C()}}var e={".json":"application/json",".xml":"application/xml",".txt":"text/plain",".html":"text/html",".htm":"text/html",".css":"text/css",".js":"application/javascript",".mjs":"application/javascript",".ts":"application/typescript",".csv":"text/csv",".md":"text/markdown",".yaml":"text/yaml",".yml":"text/yaml",".svg":"image/svg+xml",".jpg":"image/jpeg",".jpeg":"image/jpeg",".png":"image/png",".gif":"image/gif",".webp":"image/webp",".ico":"image/x-icon",".bmp":"image/bmp",".tiff":"image/tiff",".tif":"image/tiff",".pdf":"application/pdf",".doc":"application/msword",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".xls":"application/vnd.ms-excel",".xlsx":"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",".ppt":"application/vnd.ms-powerpoint",".pptx":"application/vnd.openxmlformats-officedocument.presentationml.presentation",".zip":"application/zip",".gz":"application/gzip",".tar":"application/x-tar",".rar":"application/vnd.rar",".7z":"application/x-7z-compressed",".mp3":"audio/mpeg",".wav":"audio/wav",".ogg":"audio/ogg",".m4a":"audio/mp4",".mp4":"video/mp4",".webm":"video/webm",".avi":"video/x-msvideo",".mov":"video/quicktime",".wasm":"application/wasm",".bin":"application/octet-stream",".exe":"application/octet-stream",".dll":"application/octet-stream",".so":"application/octet-stream",".dylib":"application/octet-stream"},gg=new Set(["application/json","application/xml","application/javascript","application/typescript","text/plain","text/html","text/css","text/csv","text/xml","text/markdown","text/yaml","image/svg+xml"]);function wg(g){let w=Cg(g).toLowerCase();return e[w]??"application/octet-stream"}function Eg(g){if(g.startsWith("text/"))return!1;if(gg.has(g))return!1;return!0}function k(g){return g.includes("\\")?"\\":"/"}function I(g){return g.split(/[\\/]+/).filter(Boolean)}function Rg(g){if(g.startsWith("/")||g.startsWith("\\"))return!0;if(/^[A-Za-z]:[\\/]/.test(g))return!0;if(g.startsWith("\\\\"))return!0;return!1}function z(g,w){let E=[];for(let R of w){if(!R||R===".")continue;if(R===".."){E.pop();continue}E.push(R)}return(g==="\\"?"\\":"/")+E.join(g)}function Dg(g,w){let E=k(g),R=/^[A-Za-z]:$/.test(g),S=g.match(/^([A-Za-z]:)[\\/]?/)?.[1],W=I(g),C=I(w);if(S){let O=z(E,[...W.slice(1),...C]);return`${S}${O}`}if(R){let O=z(E,C);return`${g}${O}`}return z(E,[...W,...C])}function Sg(g){if(g==="")return"/";let w=k(g),R=g.match(/^([A-Za-z]:)[\\/]?/)?.[1],D=I(g);if(R){let S=z(w,D.slice(1));return`${R}${S}`}return z(w,D)}function Cg(g){let w=Wg(g),E=w.lastIndexOf(".");if(E<=0)return"";return w.slice(E)}function Wg(g){let w=g.split(/[\\/]/);return w[w.length-1]??""}function Og(g,w){if(Rg(g))throw Error(`Absolute paths not allowed: ${g}`);let E=Dg(w,g),R=Sg(w),D=k(R);if(E!==R&&!E.startsWith(R+D))throw Error(`Path escapes base directory: ${g}`);return E}async function c(g,w={}){let E=w.basePath??w.io?.cwd()??globalThis.process?.cwd?.()??".",R=Og(g,E),D=wg(g),S=Eg(D),W;if(w.io){if(!await w.io.exists(R))throw Error(`File not found: ${g}`);W=S?await w.io.readBinary(R):await w.io.readText(R)}else if(typeof globalThis.Bun<"u"){let O=globalThis.Bun.file(R);if(!await O.exists())throw Error(`File not found: ${g}`);W=S?await O.arrayBuffer():await O.text()}else throw Error("No IO adapter provided. Provide `options.io` (Node/Bun/Tauri) to load file bodies.");return{content:W,isBinary:S,mimeType:D}}function n(g){return g.some((w)=>w.isFile)}async function h(g,w={}){let E=new FormData,R=w.basePath??w.io?.cwd()??globalThis.process?.cwd?.()??".";for(let D of g)if(D.isFile&&D.path){let S=await c(D.path,w.io?{basePath:R,io:w.io}:{basePath:R}),W=D.filename??w.io?.path.basename(D.path)??$g(D.path),C=new Blob([S.content],{type:S.mimeType});E.append(D.name,C,W)}else E.append(D.name,D.value);return E}function $g(g){let w=g.split(/[\\/]/);return w[w.length-1]??""}function b(g){let w=new URLSearchParams;for(let E of g){if(E.isFile)continue;w.append(E.name,E.value)}return w}function Fg(g){return/^[A-Za-z0-9_]+$/.test(g)}function y(g){let w=[],E=0,R=0;while(E<g.length){let D=g[E],S=g[E+1];if(D==="{"&&S==="{"){if(E>R)w.push({type:"text",value:g.slice(R,E)});let W=E;E+=2;let C=1,O="";while(E<g.length){let F=g[E],U=g[E+1];if(F==="{"&&U==="{"){C++,O+="{{",E+=2;continue}if(F==="}"&&U==="}"){if(C--,C===0){E+=2;break}O+="}}",E+=2;continue}O+=F,E++}if(C!==0)throw Error('Unterminated interpolation: missing "}}"');let G=g.slice(W,E);w.push({type:"expr",expression:O,raw:G}),R=E;continue}E++}if(R<g.length)w.push({type:"text",value:g.slice(R)});return w}function x(g,w){let E=w.split("."),R=g;for(let D of E){if(R===null||R===void 0)return;if(typeof R!=="object")return;R=R[D]}return R}function L(g){let w=g.trim();if(!w.startsWith("$"))return null;if(!w.endsWith(")"))return null;let E=w.indexOf("(");if(E===-1)return null;let R=w.slice(1,E).trim();if(!R||!Fg(R))return null;let D=w.slice(E+1,-1);return{resolverKey:`$${R}`,argText:D}}function Ug(g,w,E){let R=y(g);if(R.length===1&&R[0]?.type==="text")return g;let D="";for(let S of R){if(S.type==="text"){D+=S.value;continue}let W=S.expression.trim();if(L(W))throw Error(`Resolver calls are not allowed inside resolver args: ${S.raw}`);let C=x(w,W);if(C===void 0){if(E==="throw")throw Error(`Undefined variable: ${W}`);D+=E==="keep"?S.raw:"";continue}D+=String(C)}return D}function u(g,w,E){let R=Ug(g,w,E).trim();if(!R)return[];try{let D=JSON.parse(R);if(Array.isArray(D))return D.map((S)=>String(S))}catch{}return[R]}function Hg(g,w,E={}){let{resolvers:R={},undefinedBehavior:D="throw"}=E,S=y(g);if(S.length===1&&S[0]?.type==="text")return g;let W="";for(let C of S){if(C.type==="text"){W+=C.value;continue}let O=L(C.expression);if(O){let U=R[O.resolverKey];if(U){let $=u(O.argText,w,D),H=U(...$);if(H instanceof Promise)throw Error(`Resolver ${O.resolverKey} returned a Promise. Use createInterpolator() for async resolvers.`);W+=String(H);continue}if(D==="throw")throw Error(`Unknown resolver: ${O.resolverKey}`);W+=D==="keep"?C.raw:"";continue}let G=C.expression.trim(),F=x(w,G);if(F===void 0){if(D==="throw")throw Error(`Undefined variable: ${G}`);W+=D==="keep"?C.raw:"";continue}W+=String(F)}return W}async function Zg(g,w,E={}){let{resolvers:R={},undefinedBehavior:D="throw"}=E,S=y(g);if(S.length===1&&S[0]?.type==="text")return g;let W="";for(let C of S){if(C.type==="text"){W+=C.value;continue}let O=L(C.expression);if(O){let U=R[O.resolverKey];if(U){let $=u(O.argText,w,D),H=await U(...$);W+=String(H);continue}if(D==="throw")throw Error(`Unknown resolver: ${O.resolverKey}`);W+=D==="keep"?C.raw:"";continue}let G=C.expression.trim(),F=x(w,G);if(F===void 0){if(D==="throw")throw Error(`Undefined variable: ${G}`);W+=D==="keep"?C.raw:"";continue}W+=String(F)}return W}function f(g,w,E){if(typeof g==="string")return Hg(g,w,E);if(Array.isArray(g))return g.map((R)=>f(R,w,E));if(g!==null&&typeof g==="object"){let R={};for(let[D,S]of Object.entries(g))R[D]=f(S,w,E);return R}return g}async function T(g,w,E){if(typeof g==="string")return await Zg(g,w,E);if(Array.isArray(g))return await Promise.all(g.map((R)=>T(R,w,E)));if(g!==null&&typeof g==="object"){let R={},D=Object.entries(g),S=await Promise.all(D.map(async([W,C])=>[W,await T(C,w,E)]));for(let[W,C]of S)R[W]=C;return R}return g}function Bg(g,w,E={}){return f(g,w,E)}function v(g={}){return{async interpolate(w,E){return T(w,E,g)}}}var d=/^([^=]+?)\s*=\s*(.*)$/;function Gg(g,w){if(w&&!w.includes("form-data")&&!w.includes("x-www-form-urlencoded"))return!1;let E=g.split(/\r?\n/).filter((R)=>R.trim());if(E.length===0)return!1;if(E.length===1&&E[0]?.includes("&"))return!1;return E.every((R)=>d.test(R))}function Kg(g){let w=[],E=g.split(/\r?\n/).filter((R)=>R.trim());for(let R of E){let D=R.match(d);if(!D)continue;let S=D[1],W=D[2];if(!S)continue;let C=S.trim(),O=(W??"").trim();if(O.startsWith("@./")||O.startsWith("@{{")){O=O.slice(1);let F=O,U,$=O.indexOf(" | ");if($!==-1)F=O.slice(0,$).trim(),U=O.slice($+3).trim();w.push(Q({name:C,value:"",isFile:!0,path:F}).ifDefined("filename",U).build())}else w.push({name:C,value:O,isFile:!1})}return w}function q(g){let w=[],E=g.split(/\r?\n/),R=[],D={lines:[]};for(let S of E){let W=S.match(/^###\s*(.*)$/);if(W){if(D.lines.length>0||R.length===0)R.push(D);let C=W[1]?.trim();D=Q({lines:[]}).ifDefined("name",C||void 0).build()}else D.lines.push(S)}R.push(D);for(let S of R){if(S.lines.length===0&&!S.name)continue;let W=S.lines.join(`
2
+ `),C=Qg(W,S.name);if(C)w.push(C)}return w}function Qg(g,w){let E=g.split(/\r?\n/),R={},D=w,S="",W="",C={},O,G,F,U=!1,$=[],H=!1;for(let X=0;X<E.length;X++){let K=E[X];if(K===void 0)continue;let Z=K.trim();if(!H&&Z==="")continue;if(!H&&(Z.startsWith("#")||Z.startsWith("//"))){let _=Z.replace(/^(#|\/\/)\s*/,"").match(/^@(\w+)\s*(.*)?$/);if(_){let[,J,A]=_;if(J==="name")D=A?.trim()||D;else if(J)R[J]=A?.trim()||""}continue}if(!H){let j=Z.match(/^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\s+(\S+)(\s+HTTP\/[\d.]+)?$/i);if(j){let J=j[1],A=j[2];if(!J||!A)continue;S=J.toUpperCase(),W=A,H=!0;continue}let _=Z.match(/^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\s+(.+)$/i);if(_){let J=_[1],A=_[2];if(!J||!A)continue;S=J.toUpperCase(),W=A.trim(),H=!0;continue}continue}if(U)$.push(K);else if(Z==="")U=!0;else{let j=K.match(/^([^:]+):\s*(.*)$/);if(j){let _=j[1];if(!_)continue;let J=j[2]??"";C[_.trim()]=J.trim()}}}if(!S||!W)return null;if($.length>0){while($.length>0&&$[$.length-1]?.trim()==="")$.pop();if($.length===1){let X=$[0]?.trim().match(/^<\s+(.+)$/);if(X){let K=X[1];if(K)G={path:K}}else if($[0]?.trim())O=$[0]}else if($.length>0)O=$.join(`
3
+ `)}let V=C["Content-Type"]||C["content-type"];if(O&&Gg(O,V))F=Kg(O),O=void 0;return Q({method:S,url:W,headers:C,raw:g,meta:R}).ifDefined("name",D).ifDefined("body",O).ifDefined("bodyFile",G).ifDefined("formData",F).build()}async function ng(g){return await M(g)}async function M(g,w){if(w){let E=await w.readText(g);return q(E)}if(typeof globalThis.Bun<"u"){let D=await globalThis.Bun.file(g).text();return q(D)}throw Error("No IO adapter provided. Use parseFileWithIO(path, io) in this runtime.")}function Y(g,w){g?.(w)}function s(g,w){let E=g[0];if(!E)throw Error(w);return E}function Yg(g){let w=Math.max(g.lastIndexOf("/"),g.lastIndexOf("\\"));if(w===-1)return".";return w===0?g.slice(0,1):g.slice(0,w)}function Xg(g){if(g.startsWith("/")||g.startsWith("\\"))return!0;if(/^[A-Za-z]:[\\/]/.test(g))return!0;if(g.startsWith("\\\\"))return!0;return!1}function jg(g,w){if(!g)return w;if(!w)return g;let E=g.includes("\\")?"\\":"/",R=g.endsWith("/")||g.endsWith("\\")?g.slice(0,-1):g,D=w.startsWith("/")||w.startsWith("\\")?w.slice(1):w;return`${R}${E}${D}`}function Jg(g,w){if(w)return w.path.dirname(w.path.resolve(g));let E=globalThis.process?.cwd?.()??".",R=Xg(g)?g:jg(E,g);return Yg(R)}function _g(g,w){if(!w)return g;let E=g.Cookie||g.cookie||"";return{...g,Cookie:E?`${E}; ${w}`:w}}function Ag(g={}){let w=g.transport??N(),E=g.io,R=g.cookieStore,D=g.onEvent,S=g.headerDefaults,W=v({resolvers:g.resolvers??{}});async function C(F,U){Y(D,{type:"parseStarted",source:"string"});let $=q(F);Y(D,{type:"parseFinished",source:"string",requestCount:$.length});let H=s($,"No valid requests found in provided content.");Y(D,{type:"interpolateStarted"});let V={...U.variables??{}},X=await W.interpolate(H,V);Y(D,{type:"interpolateFinished"}),Y(D,{type:"compileStarted"});let K=U.basePath??E?.cwd()??globalThis.process?.cwd?.()??".",{executeRequest:Z}=await o(X,Q({basePath:K}).ifDefined("io",E).ifDefined("headerDefaults",S).build());return Y(D,{type:"compileFinished"}),{executeRequest:Z,baseUrl:X.url}}async function O(F,U){Y(D,{type:"parseStarted",source:"file"});let $=await M(F,E);Y(D,{type:"parseFinished",source:"file",requestCount:$.length});let H=s($,`No valid requests found in file: ${F}`);Y(D,{type:"interpolateStarted"});let V={...U.variables??{}},X=await W.interpolate(H,V);Y(D,{type:"interpolateFinished"}),Y(D,{type:"compileStarted"});let K=Jg(F,E),{executeRequest:Z}=await o(X,Q({basePath:K}).ifDefined("io",E).ifDefined("headerDefaults",S).build());return Y(D,{type:"compileFinished"}),{executeRequest:Z,baseUrl:X.url}}async function G(F,U,$){let H=F.headers??{},V=R?await R.getCookieHeader(U):void 0,X=R?_g(H,V):H,K={...F,headers:X};Y(D,{type:"fetchStarted",method:K.method,url:U});try{let Z=Q({}).ifDefined("timeout",$.timeoutMs).ifDefined("signal",$.signal).ifDefined("followRedirects",$.followRedirects).ifDefined("validateSSL",$.validateSSL).ifDefined("proxy",$.proxy).build(),j=await m(K,Z,w);if(Y(D,{type:"fetchFinished",method:K.method,url:U,status:j.status}),R)await R.setFromResponse(U,j);return j}catch(Z){throw Y(D,{type:"error",stage:"fetch",message:Z instanceof Error?Z.message:String(Z)}),Z}}return{parseString:q,async runString(F,U={}){let{executeRequest:$,baseUrl:H}=await C(F,U);return await G($,H,U)},async runFile(F,U={}){let{executeRequest:$,baseUrl:H}=await O(F,U);return await G($,H,U)}}}async function o(g,w){let E={...w.headerDefaults??{},...g.headers??{}},R=g.body;if(g.bodyFile){let S=await c(g.bodyFile.path,Q({basePath:w.basePath}).ifDefined("io",w.io).build());if(R=S.content,!E["Content-Type"]&&!E["content-type"])E["Content-Type"]=S.mimeType}else if(g.formData&&g.formData.length>0){if(n(g.formData))R=await h(g.formData,Q({basePath:w.basePath}).ifDefined("io",w.io).build()),delete E["Content-Type"],delete E["content-type"];else if(R=b(g.formData),!E["Content-Type"]&&!E["content-type"])E["Content-Type"]="application/x-www-form-urlencoded"}return{executeRequest:{method:g.method,url:g.url,headers:E,...R!==void 0?{body:R}:{}}}}export{Ag as createEngine};
4
4
 
5
- //# debugId=E0954B635A34CF1964756E2164756E21
5
+ //# debugId=A62DD58F669C6FF464756E2164756E21
6
6
  //# sourceMappingURL=index.js.map
@@ -8,11 +8,11 @@
8
8
  "import { createAutoTransport } from './runtime/auto-transport';\nimport type { Transport, TransportContext } from './runtime/types';\nimport type { ExecuteOptions, ExecuteRequest } from './types';\nimport { setOptional } from './utils/optional';\n\n/**\n * Determines if body should be attached to the request.\n * GET and HEAD requests should not have a body per HTTP spec.\n */\nfunction shouldAttachBody(method: string, body: ExecuteRequest['body']): boolean {\n return body !== undefined && !['GET', 'HEAD'].includes(method.toUpperCase());\n}\n\n/**\n * Build standard fetch RequestInit from request and execution options.\n */\nfunction buildRequestInit(\n request: ExecuteRequest,\n opts: {\n followRedirects: boolean;\n signal: AbortSignal;\n }\n): RequestInit {\n const shouldIncludeBody =\n shouldAttachBody(request.method, request.body) && request.body !== undefined;\n\n return setOptional<RequestInit>({\n method: request.method,\n redirect: opts.followRedirects ? 'follow' : 'manual',\n signal: opts.signal\n })\n .ifDefined('headers', request.headers)\n .ifDefined('body', shouldIncludeBody ? request.body : undefined)\n .build();\n}\n\n/**\n * Create an AbortSignal for request execution.\n * Uses provided signal or creates an internal timeout-based signal.\n */\nfunction createExecutionSignal(opts: { provided?: AbortSignal; timeout: number }): {\n signal: AbortSignal;\n isInternalTimeout: boolean;\n cleanup: () => void;\n} {\n if (opts.provided) {\n return {\n signal: opts.provided,\n isInternalTimeout: false,\n cleanup: () => {}\n };\n }\n\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), opts.timeout);\n\n return {\n signal: controller.signal,\n isInternalTimeout: true,\n cleanup: () => clearTimeout(timeoutId)\n };\n}\n\n/**\n * Map execution errors to user-friendly messages.\n * Converts internal timeout AbortError to descriptive timeout error.\n */\nfunction mapExecuteError(\n error: unknown,\n ctx: { timeout: number; isInternalTimeout: boolean }\n): Error {\n if (error instanceof Error && error.name === 'AbortError') {\n if (ctx.isInternalTimeout) {\n return new Error(`Request timeout after ${ctx.timeout}ms`);\n }\n }\n return error instanceof Error ? error : new Error(String(error));\n}\n\n// ============================================================================\n// Main Execute Function\n// ============================================================================\n\n/**\n * Execute an HTTP request\n * Returns a native fetch Response\n */\nexport async function execute(\n request: ExecuteRequest,\n options: ExecuteOptions = {}\n): Promise<Response> {\n return await executeWithTransport(request, options, createAutoTransport());\n}\n\n/**\n * Execute an HTTP request using an explicit transport.\n * Useful for renderer-safe environments (e.g. Tauri) or custom proxy/TLS handling.\n */\nexport async function executeWithTransport(\n request: ExecuteRequest,\n options: ExecuteOptions,\n transport: Transport\n): Promise<Response> {\n const timeout = options.timeout ?? 30000;\n\n const executionSignalOpts = setOptional<{ timeout: number; provided?: AbortSignal }>({ timeout })\n .ifDefined('provided', options.signal)\n .build();\n\n const { signal, isInternalTimeout, cleanup } = createExecutionSignal(executionSignalOpts);\n\n const runOpts = setOptional<{\n followRedirects: boolean;\n signal: AbortSignal;\n }>({\n followRedirects: options.followRedirects ?? true,\n signal\n }).build();\n\n const requestInit = buildRequestInit(request, runOpts);\n\n try {\n const ctx = setOptional<TransportContext>({})\n .ifDefined('proxy', options.proxy)\n .ifDefined('validateSSL', options.validateSSL)\n .build();\n\n return await transport.fetch(request.url, requestInit, ctx);\n } catch (error) {\n throw mapExecuteError(error, { timeout, isInternalTimeout });\n } finally {\n cleanup();\n }\n}\n",
9
9
  "import type { IO } from './runtime/types';\n\n// ============================================================================\n// Types\n// ============================================================================\n\n/**\n * Options for loading a file body.\n */\nexport interface FileLoaderOptions {\n /**\n * Base path for resolving relative file paths.\n * File paths are validated to not escape this directory.\n * @default process.cwd()\n */\n basePath?: string;\n\n /**\n * Optional IO adapter for reading files (Node/Bun/Tauri).\n * If not provided, Bun runtime fallback is used when available.\n */\n io?: IO;\n}\n\n/**\n * Result of loading a file body.\n */\nexport interface LoadedFile {\n /** File content as string (text) or ArrayBuffer (binary) */\n content: string | ArrayBuffer;\n /** Whether the file was loaded as binary */\n isBinary: boolean;\n /** Inferred MIME type based on file extension */\n mimeType: string;\n}\n\n// ============================================================================\n// MIME Type Detection\n// ============================================================================\n\n/**\n * Map of file extensions to MIME types.\n */\nconst EXTENSION_MIME_MAP: Record<string, string> = {\n // Text types\n '.json': 'application/json',\n '.xml': 'application/xml',\n '.txt': 'text/plain',\n '.html': 'text/html',\n '.htm': 'text/html',\n '.css': 'text/css',\n '.js': 'application/javascript',\n '.mjs': 'application/javascript',\n '.ts': 'application/typescript',\n '.csv': 'text/csv',\n '.md': 'text/markdown',\n '.yaml': 'text/yaml',\n '.yml': 'text/yaml',\n '.svg': 'image/svg+xml',\n\n // Binary image types\n '.jpg': 'image/jpeg',\n '.jpeg': 'image/jpeg',\n '.png': 'image/png',\n '.gif': 'image/gif',\n '.webp': 'image/webp',\n '.ico': 'image/x-icon',\n '.bmp': 'image/bmp',\n '.tiff': 'image/tiff',\n '.tif': 'image/tiff',\n\n // Binary document types\n '.pdf': 'application/pdf',\n '.doc': 'application/msword',\n '.docx': 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',\n '.xls': 'application/vnd.ms-excel',\n '.xlsx': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',\n '.ppt': 'application/vnd.ms-powerpoint',\n '.pptx': 'application/vnd.openxmlformats-officedocument.presentationml.presentation',\n\n // Binary archive types\n '.zip': 'application/zip',\n '.gz': 'application/gzip',\n '.tar': 'application/x-tar',\n '.rar': 'application/vnd.rar',\n '.7z': 'application/x-7z-compressed',\n\n // Binary audio types\n '.mp3': 'audio/mpeg',\n '.wav': 'audio/wav',\n '.ogg': 'audio/ogg',\n '.m4a': 'audio/mp4',\n\n // Binary video types\n '.mp4': 'video/mp4',\n '.webm': 'video/webm',\n '.avi': 'video/x-msvideo',\n '.mov': 'video/quicktime',\n\n // Other binary types\n '.wasm': 'application/wasm',\n '.bin': 'application/octet-stream',\n '.exe': 'application/octet-stream',\n '.dll': 'application/octet-stream',\n '.so': 'application/octet-stream',\n '.dylib': 'application/octet-stream'\n};\n\n/**\n * Set of MIME types that should be treated as text (not binary).\n */\nconst TEXT_MIME_TYPES = new Set([\n 'application/json',\n 'application/xml',\n 'application/javascript',\n 'application/typescript',\n 'text/plain',\n 'text/html',\n 'text/css',\n 'text/csv',\n 'text/xml',\n 'text/markdown',\n 'text/yaml',\n 'image/svg+xml' // SVG is XML-based text\n]);\n\n/**\n * Infer MIME type from file path based on extension.\n *\n * @param filePath - Path to the file\n * @returns Inferred MIME type, or 'application/octet-stream' if unknown\n *\n * @example\n * ```typescript\n * inferMimeType('./data.json'); // 'application/json'\n * inferMimeType('./image.png'); // 'image/png'\n * inferMimeType('./unknown'); // 'application/octet-stream'\n * ```\n */\nexport function inferMimeType(filePath: string): string {\n const ext = extname(filePath).toLowerCase();\n return EXTENSION_MIME_MAP[ext] ?? 'application/octet-stream';\n}\n\n/**\n * Determine if a MIME type represents binary content.\n *\n * @param mimeType - The MIME type to check\n * @returns true if binary, false if text\n *\n * @example\n * ```typescript\n * isBinaryMimeType('application/json'); // false\n * isBinaryMimeType('image/png'); // true\n * isBinaryMimeType('application/octet-stream'); // true\n * ```\n */\nexport function isBinaryMimeType(mimeType: string): boolean {\n // text/* types are text\n if (mimeType.startsWith('text/')) {\n return false;\n }\n // Known text application types\n if (TEXT_MIME_TYPES.has(mimeType)) {\n return false;\n }\n // Everything else is binary\n return true;\n}\n\n// ============================================================================\n// Path Utilities (runtime-neutral)\n// ============================================================================\n\nfunction sepForPath(p: string): string {\n return p.includes('\\\\') ? '\\\\' : '/';\n}\n\nfunction splitParts(p: string): string[] {\n return p.split(/[\\\\/]+/).filter(Boolean);\n}\n\nfunction isAbsolutePath(p: string): boolean {\n if (p.startsWith('/') || p.startsWith('\\\\')) return true;\n // Windows drive letters: C:\\ or C:/\n if (/^[A-Za-z]:[\\\\/]/.test(p)) return true;\n // UNC paths: \\\\server\\share\n if (p.startsWith('\\\\\\\\')) return true;\n return false;\n}\n\nfunction normalizeJoin(sep: string, parts: string[]): string {\n const out: string[] = [];\n for (const part of parts) {\n if (!part || part === '.') continue;\n if (part === '..') {\n out.pop();\n continue;\n }\n out.push(part);\n }\n return (sep === '\\\\' ? '\\\\' : '/') + out.join(sep);\n}\n\nfunction resolvePath(basePath: string, relativePath: string): string {\n const sep = sepForPath(basePath);\n\n const baseIsDrive = /^[A-Za-z]:$/.test(basePath);\n const baseDriveMatch = basePath.match(/^([A-Za-z]:)[\\\\/]?/);\n const drive = baseDriveMatch?.[1];\n\n const baseParts = splitParts(basePath);\n const relParts = splitParts(relativePath);\n\n if (drive) {\n const normalized = normalizeJoin(sep, [...baseParts.slice(1), ...relParts]);\n return `${drive}${normalized}`;\n }\n\n if (baseIsDrive) {\n const normalized = normalizeJoin(sep, relParts);\n return `${basePath}${normalized}`;\n }\n\n return normalizeJoin(sep, [...baseParts, ...relParts]);\n}\n\nfunction normalizeBase(basePath: string): string {\n if (basePath === '') return '/';\n const sep = sepForPath(basePath);\n const driveMatch = basePath.match(/^([A-Za-z]:)[\\\\/]?/);\n const drive = driveMatch?.[1];\n const parts = splitParts(basePath);\n if (drive) {\n const normalized = normalizeJoin(sep, parts.slice(1));\n return `${drive}${normalized}`;\n }\n return normalizeJoin(sep, parts);\n}\n\nfunction extname(p: string): string {\n const base = basename(p);\n const idx = base.lastIndexOf('.');\n if (idx <= 0) return '';\n return base.slice(idx);\n}\n\nfunction basename(p: string): string {\n const parts = p.split(/[\\\\/]/);\n const last = parts[parts.length - 1];\n return last ?? '';\n}\n\n/**\n * Validate that a file path is safe and doesn't escape the base directory.\n *\n * @param filePath - The file path to validate\n * @param basePath - The base directory to constrain paths within\n * @returns The resolved absolute path if valid\n * @throws Error if path is absolute or escapes the base directory\n *\n * @example\n * ```typescript\n * validateFilePath('./data.json', '/app');\n * // Returns '/app/data.json'\n *\n * validateFilePath('../../../etc/passwd', '/app');\n * // Throws: 'Path escapes base directory: ../../../etc/passwd'\n *\n * validateFilePath('/etc/passwd', '/app');\n * // Throws: 'Absolute paths not allowed: /etc/passwd'\n * ```\n */\nexport function validateFilePath(filePath: string, basePath: string): string {\n // Reject absolute paths\n if (isAbsolutePath(filePath)) {\n throw new Error(`Absolute paths not allowed: ${filePath}`);\n }\n\n // Resolve and ensure within basePath\n const resolved = resolvePath(basePath, filePath);\n const normalizedBase = normalizeBase(basePath);\n const sep = sepForPath(normalizedBase);\n\n // Check that resolved path starts with base path\n // Need to handle both exact match and subdirectory cases\n if (resolved !== normalizedBase && !resolved.startsWith(normalizedBase + sep)) {\n throw new Error(`Path escapes base directory: ${filePath}`);\n }\n\n return resolved;\n}\n\n// ============================================================================\n// File Loading\n// ============================================================================\n\n/**\n * Load a file body for use in HTTP requests.\n *\n * Automatically determines whether to load as text or binary based on\n * the file's MIME type (inferred from extension).\n *\n * @param filePath - Relative path to the file\n * @param options - Options including basePath for path resolution\n * @returns Loaded file content, binary flag, and MIME type\n * @throws Error if path validation fails or file doesn't exist\n *\n * @example\n * ```typescript\n * // Load JSON (text)\n * const jsonFile = await loadFileBody('./data.json', { basePath: '/app' });\n * // { content: '{\"key\": \"value\"}', isBinary: false, mimeType: 'application/json' }\n *\n * // Load image (binary)\n * const imageFile = await loadFileBody('./logo.png', { basePath: '/app' });\n * // { content: ArrayBuffer, isBinary: true, mimeType: 'image/png' }\n * ```\n */\nexport async function loadFileBody(\n filePath: string,\n options: FileLoaderOptions = {}\n): Promise<LoadedFile> {\n const basePath =\n options.basePath ??\n options.io?.cwd() ??\n (globalThis as unknown as { process?: { cwd?: () => string } }).process?.cwd?.() ??\n '.';\n\n // Validate path security\n const resolvedPath = validateFilePath(filePath, basePath);\n\n // Determine MIME type and binary mode\n const mimeType = inferMimeType(filePath);\n const isBinary = isBinaryMimeType(mimeType);\n\n let content: string | ArrayBuffer;\n\n if (options.io) {\n const exists = await options.io.exists(resolvedPath);\n if (!exists) {\n throw new Error(`File not found: ${filePath}`);\n }\n content = isBinary\n ? await options.io.readBinary(resolvedPath)\n : await options.io.readText(resolvedPath);\n } else if (typeof (globalThis as Record<string, unknown>)['Bun'] !== 'undefined') {\n type BunFile = {\n exists: () => Promise<boolean>;\n text: () => Promise<string>;\n arrayBuffer: () => Promise<ArrayBuffer>;\n };\n type BunGlobal = { file: (p: string) => BunFile };\n\n const bun = (globalThis as unknown as { Bun: BunGlobal }).Bun;\n const file = bun.file(resolvedPath);\n const exists = await file.exists();\n if (!exists) {\n throw new Error(`File not found: ${filePath}`);\n }\n content = isBinary ? await file.arrayBuffer() : await file.text();\n } else {\n throw new Error(\n 'No IO adapter provided. Provide `options.io` (Node/Bun/Tauri) to load file bodies.'\n );\n }\n\n return {\n content,\n isBinary,\n mimeType\n };\n}\n",
10
10
  "import { loadFileBody } from './file-loader';\nimport type { IO } from './runtime/types';\nimport type { FormField } from './types';\n\n// ============================================================================\n// Types\n// ============================================================================\n\n/**\n * Options for building form data.\n */\nexport interface BuildFormDataOptions {\n /**\n * Base path for resolving relative file paths.\n * @default process.cwd()\n */\n basePath?: string;\n\n /**\n * Optional IO adapter for reading files and path operations.\n */\n io?: IO;\n}\n\n// ============================================================================\n// Utilities\n// ============================================================================\n\n/**\n * Check if any field in the array is a file upload.\n *\n * @param fields - Array of form fields\n * @returns true if any field is a file upload\n */\nexport function hasFileFields(fields: FormField[]): boolean {\n return fields.some((field) => field.isFile);\n}\n\n// ============================================================================\n// Form Data Building\n// ============================================================================\n\n/**\n * Build FormData object from form fields.\n * Used for multipart/form-data requests (file uploads).\n *\n * @param fields - Array of form fields\n * @param options - Options including basePath for file resolution\n * @returns FormData ready for use with fetch\n *\n * @example\n * ```typescript\n * const fields: FormField[] = [\n * { name: 'title', value: 'Report', isFile: false },\n * { name: 'document', value: '', isFile: true, path: './report.pdf' },\n * ];\n *\n * const formData = await buildFormData(fields, { basePath: '/app' });\n * ```\n */\nexport async function buildFormData(\n fields: FormField[],\n options: BuildFormDataOptions = {}\n): Promise<FormData> {\n const form = new FormData();\n const basePath =\n options.basePath ??\n options.io?.cwd() ??\n (globalThis as unknown as { process?: { cwd?: () => string } }).process?.cwd?.() ??\n '.';\n\n for (const field of fields) {\n if (field.isFile && field.path) {\n // Load file content\n const loadedFile = await loadFileBody(\n field.path,\n options.io ? { basePath, io: options.io } : { basePath }\n );\n\n // Determine filename: custom filename if provided, otherwise basename of path\n const filename =\n field.filename ?? options.io?.path.basename(field.path) ?? basename(field.path);\n\n // Create Blob with appropriate MIME type\n const blob = new Blob([loadedFile.content], { type: loadedFile.mimeType });\n\n // Append as file\n form.append(field.name, blob, filename);\n } else {\n // Append as text field\n form.append(field.name, field.value);\n }\n }\n\n return form;\n}\n\nfunction basename(p: string): string {\n const parts = p.split(/[\\\\/]/);\n const last = parts[parts.length - 1];\n return last ?? '';\n}\n\n/**\n * Build URLSearchParams from form fields.\n * Used for application/x-www-form-urlencoded requests.\n *\n * Note: File fields should not be present - use buildFormData for files.\n *\n * @param fields - Array of form fields (should not contain file fields)\n * @returns URLSearchParams ready for use with fetch\n *\n * @example\n * ```typescript\n * const fields: FormField[] = [\n * { name: 'username', value: 'john', isFile: false },\n * { name: 'password', value: 'secret', isFile: false },\n * ];\n *\n * const params = buildUrlEncoded(fields);\n * // username=john&password=secret\n * ```\n */\nexport function buildUrlEncoded(fields: FormField[]): URLSearchParams {\n const params = new URLSearchParams();\n\n for (const field of fields) {\n // Skip file fields - they can't be URL encoded\n if (field.isFile) {\n continue;\n }\n params.append(field.name, field.value);\n }\n\n return params;\n}\n",
11
- "import type { InterpolateOptions, Interpolator } from './types';\n\n// Pattern to match {{variable}} or {{$resolver(arg)}}\nconst VARIABLE_PATTERN = /\\{\\{([^}]+)\\}\\}/g;\nconst RESOLVER_PATTERN = /^\\$(\\w+)\\(([^)]*)\\)$/;\n\n/**\n * Parse comma-separated arguments from a resolver argument string\n */\nfunction parseResolverArgs(argString: string): string[] {\n if (!argString.trim()) return [];\n return argString.split(',').map((arg) => arg.trim());\n}\n\n/**\n * Get a nested value from an object using dot notation\n */\nfunction getNestedValue(obj: Record<string, unknown>, path: string): unknown {\n const parts = path.split('.');\n let current: unknown = obj;\n\n for (const part of parts) {\n if (current === null || current === undefined) {\n return undefined;\n }\n if (typeof current !== 'object') {\n return undefined;\n }\n current = (current as Record<string, unknown>)[part];\n }\n\n return current;\n}\n\n/**\n * Interpolate variables into a string synchronously\n */\nfunction interpolateString(\n str: string,\n variables: Record<string, unknown>,\n options: InterpolateOptions = {}\n): string {\n const { resolvers = {}, undefinedBehavior = 'throw' } = options;\n\n return str.replace(VARIABLE_PATTERN, (match, expression: string) => {\n const trimmedExpr = expression.trim();\n\n // Check for resolver pattern: $resolver(arg)\n const resolverMatch = trimmedExpr.match(RESOLVER_PATTERN);\n if (resolverMatch) {\n const [, resolverName, arg] = resolverMatch;\n const resolver = resolvers[`$${resolverName}`];\n\n if (resolver) {\n const args = parseResolverArgs(arg ?? '');\n const result = resolver(...args);\n if (result instanceof Promise) {\n throw new Error(\n `Resolver $${resolverName} returned a Promise. Use createInterpolator() for async resolvers.`\n );\n }\n return String(result);\n }\n\n // Resolver not found\n if (undefinedBehavior === 'throw') {\n throw new Error(`Unknown resolver: $${resolverName}`);\n }\n return undefinedBehavior === 'keep' ? match : '';\n }\n\n // Regular variable lookup\n const value = getNestedValue(variables, trimmedExpr);\n\n if (value === undefined) {\n if (undefinedBehavior === 'throw') {\n throw new Error(`Undefined variable: ${trimmedExpr}`);\n }\n return undefinedBehavior === 'keep' ? match : '';\n }\n\n return String(value);\n });\n}\n\n/**\n * Interpolate variables into a string asynchronously\n */\nasync function interpolateStringAsync(\n str: string,\n variables: Record<string, unknown>,\n options: InterpolateOptions = {}\n): Promise<string> {\n const { resolvers = {}, undefinedBehavior = 'throw' } = options;\n\n // Find all matches first\n const matches: Array<{ match: string; expression: string; index: number }> = [];\n const regex = new RegExp(VARIABLE_PATTERN.source, 'g');\n\n let match: RegExpExecArray | null = regex.exec(str);\n while (match !== null) {\n const expression = match[1];\n if (expression === undefined) {\n match = regex.exec(str);\n continue;\n }\n matches.push({\n match: match[0],\n expression,\n index: match.index\n });\n match = regex.exec(str);\n }\n\n if (matches.length === 0) {\n return str;\n }\n\n // Resolve all values (potentially async)\n const resolvedValues = await Promise.all(\n matches.map(async ({ match, expression }) => {\n const trimmedExpr = expression.trim();\n\n // Check for resolver pattern: $resolver(arg)\n const resolverMatch = trimmedExpr.match(RESOLVER_PATTERN);\n if (resolverMatch) {\n const [, resolverName, arg] = resolverMatch;\n const resolver = resolvers[`$${resolverName}`];\n\n if (resolver) {\n const args = parseResolverArgs(arg ?? '');\n const result = await resolver(...args);\n return String(result);\n }\n\n // Resolver not found\n if (undefinedBehavior === 'throw') {\n throw new Error(`Unknown resolver: $${resolverName}`);\n }\n return undefinedBehavior === 'keep' ? match : '';\n }\n\n // Regular variable lookup\n const value = getNestedValue(variables, trimmedExpr);\n\n if (value === undefined) {\n if (undefinedBehavior === 'throw') {\n throw new Error(`Undefined variable: ${trimmedExpr}`);\n }\n return undefinedBehavior === 'keep' ? match : '';\n }\n\n return String(value);\n })\n );\n\n // Build result string\n let result = '';\n let lastIndex = 0;\n\n for (let i = 0; i < matches.length; i++) {\n const entry = matches[i];\n if (!entry) continue;\n const { match, index } = entry;\n result += str.slice(lastIndex, index);\n result += resolvedValues[i];\n lastIndex = index + match.length;\n }\n\n result += str.slice(lastIndex);\n return result;\n}\n\n/**\n * Deep clone and interpolate an object\n */\nfunction interpolateValue<T>(\n value: T,\n variables: Record<string, unknown>,\n options: InterpolateOptions\n): T {\n if (typeof value === 'string') {\n return interpolateString(value, variables, options) as T;\n }\n\n if (Array.isArray(value)) {\n return value.map((item) => interpolateValue(item, variables, options)) as T;\n }\n\n if (value !== null && typeof value === 'object') {\n const result: Record<string, unknown> = {};\n for (const [key, val] of Object.entries(value as Record<string, unknown>)) {\n result[key] = interpolateValue(val, variables, options);\n }\n return result as T;\n }\n\n return value;\n}\n\n/**\n * Deep clone and interpolate an object asynchronously\n */\nasync function interpolateValueAsync<T>(\n value: T,\n variables: Record<string, unknown>,\n options: InterpolateOptions\n): Promise<T> {\n if (typeof value === 'string') {\n return (await interpolateStringAsync(value, variables, options)) as T;\n }\n\n if (Array.isArray(value)) {\n return (await Promise.all(\n value.map((item) => interpolateValueAsync(item, variables, options))\n )) as T;\n }\n\n if (value !== null && typeof value === 'object') {\n const result: Record<string, unknown> = {};\n const entries = Object.entries(value as Record<string, unknown>);\n const resolvedEntries = await Promise.all(\n entries.map(async ([key, val]) => [key, await interpolateValueAsync(val, variables, options)])\n );\n for (const [key, val] of resolvedEntries) {\n result[key as string] = val;\n }\n return result as T;\n }\n\n return value;\n}\n\n/**\n * Interpolate variables into a target object or string\n * For async resolvers, use createInterpolator() instead\n */\nexport function interpolate<T>(\n target: T,\n variables: Record<string, unknown>,\n options: InterpolateOptions = {}\n): T {\n return interpolateValue(target, variables, options);\n}\n\n/**\n * Create a reusable interpolator with async resolver support\n */\nexport function createInterpolator(options: InterpolateOptions = {}): Interpolator {\n return {\n async interpolate<T>(target: T, variables: Record<string, unknown>): Promise<T> {\n return interpolateValueAsync(target, variables, options);\n }\n };\n}\n",
11
+ "import type { InterpolateOptions, Interpolator } from './types';\n\ntype TemplatePart =\n | { type: 'text'; value: string }\n | { type: 'expr'; expression: string; raw: string };\n\nfunction isWord(s: string): boolean {\n return /^[A-Za-z0-9_]+$/.test(s);\n}\n\nfunction splitTemplate(input: string): TemplatePart[] {\n const parts: TemplatePart[] = [];\n let i = 0;\n let textStart = 0;\n\n while (i < input.length) {\n const c = input[i];\n const n = input[i + 1];\n\n if (c === '{' && n === '{') {\n if (i > textStart) {\n parts.push({ type: 'text', value: input.slice(textStart, i) });\n }\n\n const start = i;\n i += 2; // consume {{\n\n let depth = 1;\n let expr = '';\n\n while (i < input.length) {\n const cc = input[i];\n const nn = input[i + 1];\n\n if (cc === '{' && nn === '{') {\n depth++;\n expr += '{{';\n i += 2;\n continue;\n }\n\n if (cc === '}' && nn === '}') {\n depth--;\n if (depth === 0) {\n i += 2; // consume final }}\n break;\n }\n expr += '}}';\n i += 2;\n continue;\n }\n\n expr += cc;\n i++;\n }\n\n if (depth !== 0) {\n throw new Error('Unterminated interpolation: missing \"}}\"');\n }\n\n const raw = input.slice(start, i);\n parts.push({ type: 'expr', expression: expr, raw });\n textStart = i;\n continue;\n }\n\n i++;\n }\n\n if (textStart < input.length) {\n parts.push({ type: 'text', value: input.slice(textStart) });\n }\n\n return parts;\n}\n\n/**\n * Get a nested value from an object using dot notation\n */\nfunction getNestedValue(obj: Record<string, unknown>, path: string): unknown {\n const parts = path.split('.');\n let current: unknown = obj;\n\n for (const part of parts) {\n if (current === null || current === undefined) {\n return undefined;\n }\n if (typeof current !== 'object') {\n return undefined;\n }\n current = (current as Record<string, unknown>)[part];\n }\n\n return current;\n}\n\nfunction parseResolverCall(expression: string): { resolverKey: string; argText: string } | null {\n const trimmed = expression.trim();\n if (!trimmed.startsWith('$')) return null;\n if (!trimmed.endsWith(')')) return null;\n\n const openIdx = trimmed.indexOf('(');\n if (openIdx === -1) return null;\n\n const name = trimmed.slice(1, openIdx).trim();\n if (!name || !isWord(name)) return null;\n\n const argText = trimmed.slice(openIdx + 1, -1);\n return { resolverKey: `$${name}`, argText };\n}\n\nfunction interpolateVariablesOnly(\n str: string,\n variables: Record<string, unknown>,\n undefinedBehavior: NonNullable<InterpolateOptions['undefinedBehavior']>\n): string {\n const parts = splitTemplate(str);\n if (parts.length === 1 && parts[0]?.type === 'text') return str;\n\n let out = '';\n for (const part of parts) {\n if (part.type === 'text') {\n out += part.value;\n continue;\n }\n\n const expr = part.expression.trim();\n if (parseResolverCall(expr)) {\n throw new Error(`Resolver calls are not allowed inside resolver args: ${part.raw}`);\n }\n\n const value = getNestedValue(variables, expr);\n if (value === undefined) {\n if (undefinedBehavior === 'throw') {\n throw new Error(`Undefined variable: ${expr}`);\n }\n out += undefinedBehavior === 'keep' ? part.raw : '';\n continue;\n }\n\n out += String(value);\n }\n\n return out;\n}\n\nfunction parseResolverArgsFromText(\n argText: string,\n variables: Record<string, unknown>,\n undefinedBehavior: NonNullable<InterpolateOptions['undefinedBehavior']>\n): string[] {\n const interpolated = interpolateVariablesOnly(argText, variables, undefinedBehavior).trim();\n if (!interpolated) return [];\n\n try {\n const parsed = JSON.parse(interpolated) as unknown;\n if (Array.isArray(parsed)) {\n return parsed.map((v) => String(v));\n }\n } catch {\n // Fallback below\n }\n\n return [interpolated];\n}\n\n/**\n * Interpolate variables into a string synchronously\n */\nfunction interpolateString(\n str: string,\n variables: Record<string, unknown>,\n options: InterpolateOptions = {}\n): string {\n const { resolvers = {}, undefinedBehavior = 'throw' } = options;\n\n const parts = splitTemplate(str);\n if (parts.length === 1 && parts[0]?.type === 'text') return str;\n\n let out = '';\n for (const part of parts) {\n if (part.type === 'text') {\n out += part.value;\n continue;\n }\n\n const parsed = parseResolverCall(part.expression);\n if (parsed) {\n const resolver = resolvers[parsed.resolverKey];\n if (resolver) {\n const args = parseResolverArgsFromText(parsed.argText, variables, undefinedBehavior);\n const result = resolver(...args);\n if (result instanceof Promise) {\n throw new Error(\n `Resolver ${parsed.resolverKey} returned a Promise. Use createInterpolator() for async resolvers.`\n );\n }\n out += String(result);\n continue;\n }\n\n if (undefinedBehavior === 'throw') {\n throw new Error(`Unknown resolver: ${parsed.resolverKey}`);\n }\n out += undefinedBehavior === 'keep' ? part.raw : '';\n continue;\n }\n\n const expr = part.expression.trim();\n const value = getNestedValue(variables, expr);\n if (value === undefined) {\n if (undefinedBehavior === 'throw') {\n throw new Error(`Undefined variable: ${expr}`);\n }\n out += undefinedBehavior === 'keep' ? part.raw : '';\n continue;\n }\n\n out += String(value);\n }\n\n return out;\n}\n\n/**\n * Interpolate variables into a string asynchronously\n */\nasync function interpolateStringAsync(\n str: string,\n variables: Record<string, unknown>,\n options: InterpolateOptions = {}\n): Promise<string> {\n const { resolvers = {}, undefinedBehavior = 'throw' } = options;\n const parts = splitTemplate(str);\n if (parts.length === 1 && parts[0]?.type === 'text') return str;\n\n let out = '';\n for (const part of parts) {\n if (part.type === 'text') {\n out += part.value;\n continue;\n }\n\n const parsed = parseResolverCall(part.expression);\n if (parsed) {\n const resolver = resolvers[parsed.resolverKey];\n if (resolver) {\n const args = parseResolverArgsFromText(parsed.argText, variables, undefinedBehavior);\n const result = await resolver(...args);\n out += String(result);\n continue;\n }\n\n if (undefinedBehavior === 'throw') {\n throw new Error(`Unknown resolver: ${parsed.resolverKey}`);\n }\n out += undefinedBehavior === 'keep' ? part.raw : '';\n continue;\n }\n\n const expr = part.expression.trim();\n const value = getNestedValue(variables, expr);\n if (value === undefined) {\n if (undefinedBehavior === 'throw') {\n throw new Error(`Undefined variable: ${expr}`);\n }\n out += undefinedBehavior === 'keep' ? part.raw : '';\n continue;\n }\n\n out += String(value);\n }\n\n return out;\n}\n\n/**\n * Deep clone and interpolate an object\n */\nfunction interpolateValue<T>(\n value: T,\n variables: Record<string, unknown>,\n options: InterpolateOptions\n): T {\n if (typeof value === 'string') {\n return interpolateString(value, variables, options) as T;\n }\n\n if (Array.isArray(value)) {\n return value.map((item) => interpolateValue(item, variables, options)) as T;\n }\n\n if (value !== null && typeof value === 'object') {\n const result: Record<string, unknown> = {};\n for (const [key, val] of Object.entries(value as Record<string, unknown>)) {\n result[key] = interpolateValue(val, variables, options);\n }\n return result as T;\n }\n\n return value;\n}\n\n/**\n * Deep clone and interpolate an object asynchronously\n */\nasync function interpolateValueAsync<T>(\n value: T,\n variables: Record<string, unknown>,\n options: InterpolateOptions\n): Promise<T> {\n if (typeof value === 'string') {\n return (await interpolateStringAsync(value, variables, options)) as T;\n }\n\n if (Array.isArray(value)) {\n return (await Promise.all(\n value.map((item) => interpolateValueAsync(item, variables, options))\n )) as T;\n }\n\n if (value !== null && typeof value === 'object') {\n const result: Record<string, unknown> = {};\n const entries = Object.entries(value as Record<string, unknown>);\n const resolvedEntries = await Promise.all(\n entries.map(async ([key, val]) => [key, await interpolateValueAsync(val, variables, options)])\n );\n for (const [key, val] of resolvedEntries) {\n result[key as string] = val;\n }\n return result as T;\n }\n\n return value;\n}\n\n/**\n * Interpolate variables into a target object or string\n * For async resolvers, use createInterpolator() instead\n */\nexport function interpolate<T>(\n target: T,\n variables: Record<string, unknown>,\n options: InterpolateOptions = {}\n): T {\n return interpolateValue(target, variables, options);\n}\n\n/**\n * Create a reusable interpolator with async resolver support\n */\nexport function createInterpolator(options: InterpolateOptions = {}): Interpolator {\n return {\n async interpolate<T>(target: T, variables: Record<string, unknown>): Promise<T> {\n return interpolateValueAsync(target, variables, options);\n }\n };\n}\n",
12
12
  "import type { IO } from './runtime/types';\nimport type { FileReference, FormField, ParsedRequest } from './types';\nimport { setOptional } from './utils/optional';\n\n// Pattern to match form field lines: name = value or name=value\nconst FORM_LINE_PATTERN = /^([^=]+?)\\s*=\\s*(.*)$/;\n\n/**\n * Check if body content matches form data syntax.\n * All non-empty lines must match the `name = value` pattern.\n *\n * This detects our friendly form syntax (multiline, spaces around =):\n * username = john\n * password = secret\n *\n * NOT traditional URL-encoded format (single line, & separators):\n * username=john&password=secret\n */\nfunction isFormBody(body: string, contentType?: string): boolean {\n // Explicit non-form Content-Type → not form\n if (\n contentType &&\n !contentType.includes('form-data') &&\n !contentType.includes('x-www-form-urlencoded')\n ) {\n return false;\n }\n\n // Empty body is not form\n const lines = body.split(/\\r?\\n/).filter((l) => l.trim());\n if (lines.length === 0) return false;\n\n // Single line with & is traditional URL-encoded format, not our form syntax\n if (lines.length === 1 && lines[0]?.includes('&')) {\n return false;\n }\n\n // All lines must match form pattern\n return lines.every((line) => FORM_LINE_PATTERN.test(line));\n}\n\n/**\n * Parse form body into FormField array.\n */\nfunction parseFormBody(body: string): FormField[] {\n const fields: FormField[] = [];\n const lines = body.split(/\\r?\\n/).filter((l) => l.trim());\n\n for (const line of lines) {\n const match = line.match(FORM_LINE_PATTERN);\n if (!match) continue;\n\n const nameRaw = match[1];\n const valueRaw = match[2];\n if (!nameRaw) continue;\n\n const name = nameRaw.trim();\n let value = (valueRaw ?? '').trim();\n\n // File reference: @./ or @{{ for variable paths\n const isFile = value.startsWith('@./') || value.startsWith('@{{');\n\n if (isFile) {\n // Remove @ prefix\n value = value.slice(1);\n\n // Check for custom filename: @./path | filename\n let filePath = value;\n let filename: string | undefined;\n\n const pipeIndex = value.indexOf(' | ');\n if (pipeIndex !== -1) {\n filePath = value.slice(0, pipeIndex).trim();\n filename = value.slice(pipeIndex + 3).trim();\n }\n\n fields.push(\n setOptional<FormField>({\n name,\n value: '',\n isFile: true,\n path: filePath\n })\n .ifDefined('filename', filename)\n .build()\n );\n } else {\n fields.push({ name, value, isFile: false });\n }\n }\n\n return fields;\n}\n\n/**\n * Parse .http file content into structured request objects\n */\nexport function parse(content: string): ParsedRequest[] {\n const requests: ParsedRequest[] = [];\n\n // Split by request separators (###)\n // The regex captures the optional name after ###\n // Handle both LF and CRLF line endings\n const lines = content.split(/\\r?\\n/);\n const blocks: Array<{ name?: string; lines: string[] }> = [];\n let currentBlock: { name?: string; lines: string[] } = { lines: [] };\n\n for (const line of lines) {\n const separatorMatch = line.match(/^###\\s*(.*)$/);\n if (separatorMatch) {\n // Save current block if it has content\n if (currentBlock.lines.length > 0 || blocks.length === 0) {\n blocks.push(currentBlock);\n }\n // Start new block with optional name from separator\n const blockName = separatorMatch[1]?.trim();\n currentBlock = setOptional<{ name?: string; lines: string[] }>({ lines: [] })\n .ifDefined('name', blockName || undefined)\n .build();\n } else {\n currentBlock.lines.push(line);\n }\n }\n\n // Don't forget the last block\n blocks.push(currentBlock);\n\n // Parse each block\n for (const block of blocks) {\n if (block.lines.length === 0 && !block.name) {\n continue;\n }\n\n const blockContent = block.lines.join('\\n');\n const request = parseRequestBlock(blockContent, block.name);\n if (request) {\n requests.push(request);\n }\n }\n\n return requests;\n}\n\n/**\n * Parse a single request block\n */\nfunction parseRequestBlock(block: string, defaultName?: string): ParsedRequest | null {\n const lines = block.split(/\\r?\\n/);\n const meta: Record<string, string> = {};\n let name = defaultName;\n let method = '';\n let url = '';\n const headers: Record<string, string> = {};\n let body: string | undefined;\n let bodyFile: FileReference | undefined;\n let formData: FormField[] | undefined;\n let inBody = false;\n const bodyLines: string[] = [];\n let requestLineFound = false;\n\n for (let i = 0; i < lines.length; i++) {\n const line = lines[i];\n if (line === undefined) continue;\n const trimmedLine = line.trim();\n\n // Skip empty lines before request line\n if (!requestLineFound && trimmedLine === '') {\n continue;\n }\n\n // Handle comments and directives\n if (!requestLineFound && (trimmedLine.startsWith('#') || trimmedLine.startsWith('//'))) {\n const commentContent = trimmedLine.replace(/^(#|\\/\\/)\\s*/, '');\n\n // Check for @directive\n const directiveMatch = commentContent.match(/^@(\\w+)\\s*(.*)?$/);\n if (directiveMatch) {\n const [, directive, value] = directiveMatch;\n if (directive === 'name') {\n name = value?.trim() || name;\n } else if (directive) {\n meta[directive] = value?.trim() || '';\n }\n }\n continue;\n }\n\n // Parse request line (METHOD URL HTTP/VERSION)\n if (!requestLineFound) {\n const requestLineMatch = trimmedLine.match(\n /^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\\s+(\\S+)(\\s+HTTP\\/[\\d.]+)?$/i\n );\n if (requestLineMatch) {\n const methodMatch = requestLineMatch[1];\n const urlMatch = requestLineMatch[2];\n if (!methodMatch || !urlMatch) continue;\n method = methodMatch.toUpperCase();\n url = urlMatch;\n requestLineFound = true;\n continue;\n }\n\n // Also support just METHOD URL without HTTP version\n const simpleRequestMatch = trimmedLine.match(\n /^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\\s+(.+)$/i\n );\n if (simpleRequestMatch) {\n const methodMatch = simpleRequestMatch[1];\n const urlMatch = simpleRequestMatch[2];\n if (!methodMatch || !urlMatch) continue;\n method = methodMatch.toUpperCase();\n url = urlMatch.trim();\n requestLineFound = true;\n continue;\n }\n\n // Skip non-matching lines before request\n continue;\n }\n\n // After request line - handle headers and body\n if (inBody) {\n bodyLines.push(line);\n } else if (trimmedLine === '') {\n // Empty line marks start of body\n inBody = true;\n } else {\n // Parse header\n const headerMatch = line.match(/^([^:]+):\\s*(.*)$/);\n if (headerMatch) {\n const headerName = headerMatch[1];\n if (!headerName) continue;\n const headerValue = headerMatch[2] ?? '';\n headers[headerName.trim()] = headerValue.trim();\n }\n }\n }\n\n // No valid request found\n if (!method || !url) {\n return null;\n }\n\n // Process body\n if (bodyLines.length > 0) {\n // Remove trailing empty lines\n while (bodyLines.length > 0 && bodyLines[bodyLines.length - 1]?.trim() === '') {\n bodyLines.pop();\n }\n\n // Check for file reference syntax: < ./path\n if (bodyLines.length === 1) {\n const fileRefMatch = bodyLines[0]?.trim().match(/^<\\s+(.+)$/);\n if (fileRefMatch) {\n const filePath = fileRefMatch[1];\n if (filePath) {\n bodyFile = { path: filePath };\n }\n } else if (bodyLines[0]?.trim()) {\n body = bodyLines[0];\n }\n } else if (bodyLines.length > 0) {\n body = bodyLines.join('\\n');\n }\n }\n\n // Check if body matches form data syntax\n // Get Content-Type header (case-insensitive)\n const contentType = headers['Content-Type'] || headers['content-type'];\n\n if (body && isFormBody(body, contentType)) {\n formData = parseFormBody(body);\n body = undefined; // Clear body since we're using formData\n }\n\n return setOptional<ParsedRequest>({\n method,\n url,\n headers,\n raw: block,\n meta\n })\n .ifDefined('name', name)\n .ifDefined('body', body)\n .ifDefined('bodyFile', bodyFile)\n .ifDefined('formData', formData)\n .build();\n}\n\n/**\n * Parse .http file from filesystem\n */\nexport async function parseFile(path: string): Promise<ParsedRequest[]> {\n return await parseFileWithIO(path);\n}\n\n/**\n * Parse .http file from filesystem using an IO adapter.\n * If `io` is omitted, Bun runtime fallback is used when available.\n */\nexport async function parseFileWithIO(path: string, io?: IO): Promise<ParsedRequest[]> {\n if (io) {\n const content = await io.readText(path);\n return parse(content);\n }\n\n if (typeof (globalThis as Record<string, unknown>)['Bun'] !== 'undefined') {\n type BunFile = { text: () => Promise<string> };\n type BunGlobal = { file: (p: string) => BunFile };\n\n const bun = (globalThis as unknown as { Bun: BunGlobal }).Bun;\n const file = bun.file(path);\n const content = await file.text();\n return parse(content);\n }\n\n throw new Error('No IO adapter provided. Use parseFileWithIO(path, io) in this runtime.');\n}\n",
13
- "import { executeWithTransport } from '../execute';\nimport { loadFileBody } from '../file-loader';\nimport { buildFormData, buildUrlEncoded, hasFileFields } from '../form-data-builder';\nimport { createInterpolator } from '../interpolate';\nimport { parse, parseFileWithIO } from '../parser';\nimport { createAutoTransport } from '../runtime/auto-transport';\nimport type { CookieStore, EngineEvent, EventSink, IO, Transport } from '../runtime/types';\nimport type { ExecuteOptions, ExecuteRequest, FormField, Resolver } from '../types';\nimport { setOptional } from '../utils/optional';\n\nexport type EngineConfig = {\n transport?: Transport;\n io?: IO;\n cookieStore?: CookieStore;\n resolvers?: Record<string, Resolver>;\n onEvent?: EventSink;\n headerDefaults?: Record<string, string>;\n};\n\nexport type EngineRunOptions = {\n variables?: Record<string, unknown>;\n timeoutMs?: number;\n signal?: AbortSignal;\n followRedirects?: boolean;\n validateSSL?: boolean;\n proxy?: string;\n\n /**\n * Base path for resolving file references when running from string content.\n * When running from file, this is derived from the .http file directory.\n */\n basePath?: string;\n};\n\nexport type Engine = {\n parseString: (httpText: string) => ReturnType<typeof parse>;\n runString: (httpText: string, options?: EngineRunOptions) => Promise<Response>;\n runFile: (path: string, options?: EngineRunOptions) => Promise<Response>;\n};\n\nfunction emit(onEvent: EventSink | undefined, event: EngineEvent): void {\n onEvent?.(event);\n}\n\nfunction firstOrThrow<T>(arr: T[], ctx: string): T {\n const first = arr[0];\n if (!first) {\n throw new Error(ctx);\n }\n return first;\n}\n\nfunction dirnameFromPath(p: string): string {\n const idx = Math.max(p.lastIndexOf('/'), p.lastIndexOf('\\\\'));\n if (idx === -1) return '.';\n return idx === 0 ? p.slice(0, 1) : p.slice(0, idx);\n}\n\nfunction isAbsolutePath(p: string): boolean {\n if (p.startsWith('/') || p.startsWith('\\\\')) return true;\n if (/^[A-Za-z]:[\\\\/]/.test(p)) return true;\n if (p.startsWith('\\\\\\\\')) return true;\n return false;\n}\n\nfunction joinWithSep(a: string, b: string): string {\n if (!a) return b;\n if (!b) return a;\n const sep = a.includes('\\\\') ? '\\\\' : '/';\n const aTrim = a.endsWith('/') || a.endsWith('\\\\') ? a.slice(0, -1) : a;\n const bTrim = b.startsWith('/') || b.startsWith('\\\\') ? b.slice(1) : b;\n return `${aTrim}${sep}${bTrim}`;\n}\n\nfunction getFileBasePath(filePath: string, io?: IO): string {\n if (io) {\n return io.path.dirname(io.path.resolve(filePath));\n }\n\n const cwd =\n (globalThis as unknown as { process?: { cwd?: () => string } }).process?.cwd?.() ?? '.';\n const absolute = isAbsolutePath(filePath) ? filePath : joinWithSep(cwd, filePath);\n return dirnameFromPath(absolute);\n}\n\nfunction withCookieHeader(\n headers: Record<string, string>,\n cookie: string | undefined\n): Record<string, string> {\n if (!cookie) return headers;\n const existing = headers['Cookie'] || headers['cookie'] || '';\n return {\n ...headers,\n Cookie: existing ? `${existing}; ${cookie}` : cookie\n };\n}\n\nexport function createEngine(config: EngineConfig = {}): Engine {\n const transport = config.transport ?? createAutoTransport();\n const io = config.io;\n const cookieStore = config.cookieStore;\n const onEvent = config.onEvent;\n const headerDefaults = config.headerDefaults;\n\n const interpolator = createInterpolator({ resolvers: config.resolvers ?? {} });\n\n async function compileFromString(\n httpText: string,\n options: EngineRunOptions\n ): Promise<{\n executeRequest: ExecuteRequest;\n baseUrl: string;\n }> {\n emit(onEvent, { type: 'parseStarted', source: 'string' });\n const requests = parse(httpText);\n emit(onEvent, { type: 'parseFinished', source: 'string', requestCount: requests.length });\n\n const request = firstOrThrow(requests, 'No valid requests found in provided content.');\n\n emit(onEvent, { type: 'interpolateStarted' });\n const mergedVars = { ...(options.variables ?? {}) };\n const interpolated = await interpolator.interpolate(request, mergedVars);\n emit(onEvent, { type: 'interpolateFinished' });\n\n emit(onEvent, { type: 'compileStarted' });\n const basePath =\n options.basePath ??\n io?.cwd() ??\n (globalThis as unknown as { process?: { cwd?: () => string } }).process?.cwd?.() ??\n '.';\n\n const { executeRequest } = await compileExecuteRequest(\n interpolated,\n setOptional<{ basePath: string; io?: IO; headerDefaults?: Record<string, string> }>({\n basePath\n })\n .ifDefined('io', io)\n .ifDefined('headerDefaults', headerDefaults)\n .build()\n );\n emit(onEvent, { type: 'compileFinished' });\n\n return { executeRequest, baseUrl: interpolated.url };\n }\n\n async function compileFromFile(\n path: string,\n options: EngineRunOptions\n ): Promise<{\n executeRequest: ExecuteRequest;\n baseUrl: string;\n }> {\n emit(onEvent, { type: 'parseStarted', source: 'file' });\n const requests = await parseFileWithIO(path, io);\n emit(onEvent, { type: 'parseFinished', source: 'file', requestCount: requests.length });\n\n const request = firstOrThrow(requests, `No valid requests found in file: ${path}`);\n\n emit(onEvent, { type: 'interpolateStarted' });\n const mergedVars = { ...(options.variables ?? {}) };\n const interpolated = await interpolator.interpolate(request, mergedVars);\n emit(onEvent, { type: 'interpolateFinished' });\n\n emit(onEvent, { type: 'compileStarted' });\n const basePath = getFileBasePath(path, io);\n const { executeRequest } = await compileExecuteRequest(\n interpolated,\n setOptional<{ basePath: string; io?: IO; headerDefaults?: Record<string, string> }>({\n basePath\n })\n .ifDefined('io', io)\n .ifDefined('headerDefaults', headerDefaults)\n .build()\n );\n emit(onEvent, { type: 'compileFinished' });\n\n return { executeRequest, baseUrl: interpolated.url };\n }\n\n async function runCompiled(\n executeRequest: ExecuteRequest,\n urlForCookies: string,\n options: EngineRunOptions\n ): Promise<Response> {\n const headers = executeRequest.headers ?? {};\n\n const cookieHeader = cookieStore ? await cookieStore.getCookieHeader(urlForCookies) : undefined;\n const headersWithCookies = cookieStore ? withCookieHeader(headers, cookieHeader) : headers;\n\n const requestWithCookies: ExecuteRequest = {\n ...executeRequest,\n headers: headersWithCookies\n };\n\n emit(onEvent, { type: 'fetchStarted', method: requestWithCookies.method, url: urlForCookies });\n\n try {\n const execOptions = setOptional<ExecuteOptions>({})\n .ifDefined('timeout', options.timeoutMs)\n .ifDefined('signal', options.signal)\n .ifDefined('followRedirects', options.followRedirects)\n .ifDefined('validateSSL', options.validateSSL)\n .ifDefined('proxy', options.proxy)\n .build();\n\n const response = await executeWithTransport(requestWithCookies, execOptions, transport);\n\n emit(onEvent, {\n type: 'fetchFinished',\n method: requestWithCookies.method,\n url: urlForCookies,\n status: response.status\n });\n\n if (cookieStore) {\n await cookieStore.setFromResponse(urlForCookies, response);\n }\n\n return response;\n } catch (e) {\n emit(onEvent, {\n type: 'error',\n stage: 'fetch',\n message: e instanceof Error ? e.message : String(e)\n });\n throw e;\n }\n }\n\n return {\n parseString: parse,\n async runString(httpText, options = {}) {\n const { executeRequest, baseUrl } = await compileFromString(httpText, options);\n return await runCompiled(executeRequest, baseUrl, options);\n },\n async runFile(path, options = {}) {\n const { executeRequest, baseUrl } = await compileFromFile(path, options);\n return await runCompiled(executeRequest, baseUrl, options);\n }\n };\n}\n\nasync function compileExecuteRequest(\n interpolated: {\n method: string;\n url: string;\n headers: Record<string, string>;\n body?: string;\n bodyFile?: { path: string };\n formData?: FormField[];\n },\n ctx: { basePath: string; io?: IO; headerDefaults?: Record<string, string> }\n): Promise<{ executeRequest: ExecuteRequest }> {\n const headers: Record<string, string> = {\n ...(ctx.headerDefaults ?? {}),\n ...(interpolated.headers ?? {})\n };\n\n let body: ExecuteRequest['body'] = interpolated.body;\n\n if (interpolated.bodyFile) {\n const loadedFile = await loadFileBody(\n interpolated.bodyFile.path,\n setOptional<{ basePath: string; io?: IO }>({ basePath: ctx.basePath })\n .ifDefined('io', ctx.io)\n .build()\n );\n\n body = loadedFile.content;\n\n if (!headers['Content-Type'] && !headers['content-type']) {\n headers['Content-Type'] = loadedFile.mimeType;\n }\n } else if (interpolated.formData && interpolated.formData.length > 0) {\n const hasFiles = hasFileFields(interpolated.formData);\n\n if (hasFiles) {\n body = await buildFormData(\n interpolated.formData,\n setOptional<{ basePath: string; io?: IO }>({ basePath: ctx.basePath })\n .ifDefined('io', ctx.io)\n .build()\n );\n delete headers['Content-Type'];\n delete headers['content-type'];\n } else {\n body = buildUrlEncoded(interpolated.formData);\n if (!headers['Content-Type'] && !headers['content-type']) {\n headers['Content-Type'] = 'application/x-www-form-urlencoded';\n }\n }\n }\n\n const executeRequest: ExecuteRequest = {\n method: interpolated.method,\n url: interpolated.url,\n headers,\n ...(body !== undefined ? { body } : {})\n };\n\n return { executeRequest };\n}\n"
13
+ "import { executeWithTransport } from '../execute';\nimport { loadFileBody } from '../file-loader';\nimport { buildFormData, buildUrlEncoded, hasFileFields } from '../form-data-builder';\nimport { createInterpolator } from '../interpolate';\nimport { parse, parseFileWithIO } from '../parser';\nimport { createAutoTransport } from '../runtime/auto-transport';\nimport type { CookieStore, EngineEvent, EventSink, IO, Transport } from '../runtime/types';\nimport type { ExecuteOptions, ExecuteRequest, FormField, Resolver } from '../types';\nimport { setOptional } from '../utils/optional';\n\nexport type EngineConfig = {\n transport?: Transport;\n io?: IO;\n cookieStore?: CookieStore;\n resolvers?: Record<string, Resolver>;\n onEvent?: EventSink;\n headerDefaults?: Record<string, string>;\n};\n\nexport type EngineRunOptions = {\n variables?: Record<string, unknown>;\n timeoutMs?: number;\n signal?: AbortSignal;\n followRedirects?: boolean;\n validateSSL?: boolean;\n proxy?: string;\n basePath?: string;\n};\n\nexport type Engine = {\n parseString: (httpText: string) => ReturnType<typeof parse>;\n runString: (httpText: string, options?: EngineRunOptions) => Promise<Response>;\n runFile: (path: string, options?: EngineRunOptions) => Promise<Response>;\n};\n\nfunction emit(onEvent: EventSink | undefined, event: EngineEvent): void {\n onEvent?.(event);\n}\n\nfunction firstOrThrow<T>(arr: T[], ctx: string): T {\n const first = arr[0];\n if (!first) {\n throw new Error(ctx);\n }\n return first;\n}\n\nfunction dirnameFromPath(p: string): string {\n const idx = Math.max(p.lastIndexOf('/'), p.lastIndexOf('\\\\'));\n if (idx === -1) return '.';\n return idx === 0 ? p.slice(0, 1) : p.slice(0, idx);\n}\n\nfunction isAbsolutePath(p: string): boolean {\n if (p.startsWith('/') || p.startsWith('\\\\')) return true;\n if (/^[A-Za-z]:[\\\\/]/.test(p)) return true;\n if (p.startsWith('\\\\\\\\')) return true;\n return false;\n}\n\nfunction joinWithSep(a: string, b: string): string {\n if (!a) return b;\n if (!b) return a;\n const sep = a.includes('\\\\') ? '\\\\' : '/';\n const aTrim = a.endsWith('/') || a.endsWith('\\\\') ? a.slice(0, -1) : a;\n const bTrim = b.startsWith('/') || b.startsWith('\\\\') ? b.slice(1) : b;\n return `${aTrim}${sep}${bTrim}`;\n}\n\nfunction getFileBasePath(filePath: string, io?: IO): string {\n if (io) {\n return io.path.dirname(io.path.resolve(filePath));\n }\n\n const cwd =\n (globalThis as unknown as { process?: { cwd?: () => string } }).process?.cwd?.() ?? '.';\n const absolute = isAbsolutePath(filePath) ? filePath : joinWithSep(cwd, filePath);\n return dirnameFromPath(absolute);\n}\n\nfunction withCookieHeader(\n headers: Record<string, string>,\n cookie: string | undefined\n): Record<string, string> {\n if (!cookie) return headers;\n const existing = headers['Cookie'] || headers['cookie'] || '';\n return {\n ...headers,\n Cookie: existing ? `${existing}; ${cookie}` : cookie\n };\n}\n\nexport function createEngine(config: EngineConfig = {}): Engine {\n const transport = config.transport ?? createAutoTransport();\n const io = config.io;\n const cookieStore = config.cookieStore;\n const onEvent = config.onEvent;\n const headerDefaults = config.headerDefaults;\n\n const interpolator = createInterpolator({ resolvers: config.resolvers ?? {} });\n\n async function compileFromString(\n httpText: string,\n options: EngineRunOptions\n ): Promise<{\n executeRequest: ExecuteRequest;\n baseUrl: string;\n }> {\n emit(onEvent, { type: 'parseStarted', source: 'string' });\n const requests = parse(httpText);\n emit(onEvent, { type: 'parseFinished', source: 'string', requestCount: requests.length });\n\n const request = firstOrThrow(requests, 'No valid requests found in provided content.');\n\n emit(onEvent, { type: 'interpolateStarted' });\n const mergedVars = { ...(options.variables ?? {}) };\n const interpolated = await interpolator.interpolate(request, mergedVars);\n emit(onEvent, { type: 'interpolateFinished' });\n\n emit(onEvent, { type: 'compileStarted' });\n const basePath =\n options.basePath ??\n io?.cwd() ??\n (globalThis as unknown as { process?: { cwd?: () => string } }).process?.cwd?.() ??\n '.';\n\n const { executeRequest } = await compileExecuteRequest(\n interpolated,\n setOptional<{ basePath: string; io?: IO; headerDefaults?: Record<string, string> }>({\n basePath\n })\n .ifDefined('io', io)\n .ifDefined('headerDefaults', headerDefaults)\n .build()\n );\n emit(onEvent, { type: 'compileFinished' });\n\n return { executeRequest, baseUrl: interpolated.url };\n }\n\n async function compileFromFile(\n path: string,\n options: EngineRunOptions\n ): Promise<{\n executeRequest: ExecuteRequest;\n baseUrl: string;\n }> {\n emit(onEvent, { type: 'parseStarted', source: 'file' });\n const requests = await parseFileWithIO(path, io);\n emit(onEvent, { type: 'parseFinished', source: 'file', requestCount: requests.length });\n\n const request = firstOrThrow(requests, `No valid requests found in file: ${path}`);\n\n emit(onEvent, { type: 'interpolateStarted' });\n const mergedVars = { ...(options.variables ?? {}) };\n const interpolated = await interpolator.interpolate(request, mergedVars);\n emit(onEvent, { type: 'interpolateFinished' });\n\n emit(onEvent, { type: 'compileStarted' });\n const basePath = getFileBasePath(path, io);\n const { executeRequest } = await compileExecuteRequest(\n interpolated,\n setOptional<{ basePath: string; io?: IO; headerDefaults?: Record<string, string> }>({\n basePath\n })\n .ifDefined('io', io)\n .ifDefined('headerDefaults', headerDefaults)\n .build()\n );\n emit(onEvent, { type: 'compileFinished' });\n\n return { executeRequest, baseUrl: interpolated.url };\n }\n\n async function runCompiled(\n executeRequest: ExecuteRequest,\n urlForCookies: string,\n options: EngineRunOptions\n ): Promise<Response> {\n const headers = executeRequest.headers ?? {};\n\n const cookieHeader = cookieStore ? await cookieStore.getCookieHeader(urlForCookies) : undefined;\n const headersWithCookies = cookieStore ? withCookieHeader(headers, cookieHeader) : headers;\n\n const requestWithCookies: ExecuteRequest = {\n ...executeRequest,\n headers: headersWithCookies\n };\n\n emit(onEvent, { type: 'fetchStarted', method: requestWithCookies.method, url: urlForCookies });\n\n try {\n const execOptions = setOptional<ExecuteOptions>({})\n .ifDefined('timeout', options.timeoutMs)\n .ifDefined('signal', options.signal)\n .ifDefined('followRedirects', options.followRedirects)\n .ifDefined('validateSSL', options.validateSSL)\n .ifDefined('proxy', options.proxy)\n .build();\n\n const response = await executeWithTransport(requestWithCookies, execOptions, transport);\n\n emit(onEvent, {\n type: 'fetchFinished',\n method: requestWithCookies.method,\n url: urlForCookies,\n status: response.status\n });\n\n if (cookieStore) {\n await cookieStore.setFromResponse(urlForCookies, response);\n }\n\n return response;\n } catch (e) {\n emit(onEvent, {\n type: 'error',\n stage: 'fetch',\n message: e instanceof Error ? e.message : String(e)\n });\n throw e;\n }\n }\n\n return {\n parseString: parse,\n async runString(httpText, options = {}) {\n const { executeRequest, baseUrl } = await compileFromString(httpText, options);\n return await runCompiled(executeRequest, baseUrl, options);\n },\n async runFile(path, options = {}) {\n const { executeRequest, baseUrl } = await compileFromFile(path, options);\n return await runCompiled(executeRequest, baseUrl, options);\n }\n };\n}\n\nasync function compileExecuteRequest(\n interpolated: {\n method: string;\n url: string;\n headers: Record<string, string>;\n body?: string;\n bodyFile?: { path: string };\n formData?: FormField[];\n },\n ctx: { basePath: string; io?: IO; headerDefaults?: Record<string, string> }\n): Promise<{ executeRequest: ExecuteRequest }> {\n const headers: Record<string, string> = {\n ...(ctx.headerDefaults ?? {}),\n ...(interpolated.headers ?? {})\n };\n\n let body: ExecuteRequest['body'] = interpolated.body;\n\n if (interpolated.bodyFile) {\n const loadedFile = await loadFileBody(\n interpolated.bodyFile.path,\n setOptional<{ basePath: string; io?: IO }>({ basePath: ctx.basePath })\n .ifDefined('io', ctx.io)\n .build()\n );\n\n body = loadedFile.content;\n\n if (!headers['Content-Type'] && !headers['content-type']) {\n headers['Content-Type'] = loadedFile.mimeType;\n }\n } else if (interpolated.formData && interpolated.formData.length > 0) {\n const hasFiles = hasFileFields(interpolated.formData);\n\n if (hasFiles) {\n body = await buildFormData(\n interpolated.formData,\n setOptional<{ basePath: string; io?: IO }>({ basePath: ctx.basePath })\n .ifDefined('io', ctx.io)\n .build()\n );\n delete headers['Content-Type'];\n delete headers['content-type'];\n } else {\n body = buildUrlEncoded(interpolated.formData);\n if (!headers['Content-Type'] && !headers['content-type']) {\n headers['Content-Type'] = 'application/x-www-form-urlencoded';\n }\n }\n }\n\n const executeRequest: ExecuteRequest = {\n method: interpolated.method,\n url: interpolated.url,\n headers,\n ...(body !== undefined ? { body } : {})\n };\n\n return { executeRequest };\n}\n"
14
14
  ],
15
- "mappings": "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",
16
- "debugId": "E0954B635A34CF1964756E2164756E21",
15
+ "mappings": "sEAIA,SAAS,CAAW,CAAC,EAAqB,CACxC,MAAU,MACR,GAAG,6EACL,EASK,SAAS,CAAoB,CAAC,EAAuB,MAAkB,CAC5E,MAAO,CACL,aAAc,CAAE,MAAO,GAAO,YAAa,EAAM,OAC3C,MAAK,CAAC,EAAK,EAAM,EAAK,CAC1B,GAAI,EAAI,MAAO,EAAY,OAAO,EAClC,GAAI,EAAI,cAAgB,GAAO,EAAY,mBAAmB,EAC9D,OAAO,MAAM,EAAU,EAAK,CAAI,EAEpC,ECnBF,SAAS,CAAM,EAAY,CACzB,OAAO,OAAQ,WAAuC,IAAW,IAS5D,SAAS,CAAmB,EAAc,CAC/C,GAAI,CAAC,EAAO,EACV,OAAO,EAAqB,KAAK,EAGnC,MAAO,CACL,aAAc,CAAE,MAAO,GAAM,YAAa,EAAK,OACzC,MAAK,CAAC,EAAK,EAAM,EAAK,CAC1B,IAAM,EAAwB,IAAM,GAAQ,CAAC,CAAG,EAEhD,GAAI,EAAI,QAAU,OAChB,EAAQ,MAAQ,EAAI,MAGtB,GAAI,EAAI,cAAgB,GACtB,EAAQ,IAAM,CAAE,mBAAoB,EAAM,EAG5C,OAAO,MAAM,MAAM,EAAK,CAAO,EAEnC,ECMK,SAAS,CAA6B,CAAC,EAA6B,CACzE,IAAI,EAAS,IAAK,CAAK,EAEjB,EAA8B,CAClC,IAAI,CAAC,EAAW,EAAO,CACrB,GAAI,EACF,EAAS,IAAK,KAAW,CAAM,EAEjC,OAAO,GAGT,SAAS,CAAC,EAAK,EAAO,CACpB,GAAI,IAAU,OACZ,EAAS,IAAK,GAAS,GAAM,CAAM,EAErC,OAAO,GAGT,KAAK,EAAG,CACN,OAAO,EAEX,EAEA,OAAO,ECvDT,SAAS,CAAgB,CAAC,EAAgB,EAAuC,CAC/E,OAAO,IAAS,QAAa,CAAC,CAAC,MAAO,MAAM,EAAE,SAAS,EAAO,YAAY,CAAC,EAM7E,SAAS,CAAgB,CACvB,EACA,EAIa,CACb,IAAM,EACJ,EAAiB,EAAQ,OAAQ,EAAQ,IAAI,GAAK,EAAQ,OAAS,OAErE,OAAO,EAAyB,CAC9B,OAAQ,EAAQ,OAChB,SAAU,EAAK,gBAAkB,SAAW,SAC5C,OAAQ,EAAK,MACf,CAAC,EACE,UAAU,UAAW,EAAQ,OAAO,EACpC,UAAU,OAAQ,EAAoB,EAAQ,KAAO,MAAS,EAC9D,MAAM,EAOX,SAAS,CAAqB,CAAC,EAI7B,CACA,GAAI,EAAK,SACP,MAAO,CACL,OAAQ,EAAK,SACb,kBAAmB,GACnB,QAAS,IAAM,EACjB,EAGF,IAAM,EAAa,IAAI,gBACjB,EAAY,WAAW,IAAM,EAAW,MAAM,EAAG,EAAK,OAAO,EAEnE,MAAO,CACL,OAAQ,EAAW,OACnB,kBAAmB,GACnB,QAAS,IAAM,aAAa,CAAS,CACvC,EAOF,SAAS,CAAe,CACtB,EACA,EACO,CACP,GAAI,aAAiB,OAAS,EAAM,OAAS,cAC3C,GAAI,EAAI,kBACN,OAAW,MAAM,yBAAyB,EAAI,WAAW,EAG7D,OAAO,aAAiB,MAAQ,EAAY,MAAM,OAAO,CAAK,CAAC,EAsBjE,eAAsB,CAAoB,CACxC,EACA,EACA,EACmB,CACnB,IAAM,EAAU,EAAQ,SAAW,MAE7B,EAAsB,EAAyD,CAAE,SAAQ,CAAC,EAC7F,UAAU,WAAY,EAAQ,MAAM,EACpC,MAAM,GAED,SAAQ,oBAAmB,WAAY,EAAsB,CAAmB,EAElF,EAAU,EAGb,CACD,gBAAiB,EAAQ,iBAAmB,GAC5C,QACF,CAAC,EAAE,MAAM,EAEH,EAAc,EAAiB,EAAS,CAAO,EAErD,GAAI,CACF,IAAM,EAAM,EAA8B,CAAC,CAAC,EACzC,UAAU,QAAS,EAAQ,KAAK,EAChC,UAAU,cAAe,EAAQ,WAAW,EAC5C,MAAM,EAET,OAAO,MAAM,EAAU,MAAM,EAAQ,IAAK,EAAa,CAAG,EAC1D,MAAO,EAAO,CACd,MAAM,EAAgB,EAAO,CAAE,UAAS,mBAAkB,CAAC,SAC3D,CACA,EAAQ,GCxFZ,IAAM,EAA6C,CAEjD,QAAS,mBACT,OAAQ,kBACR,OAAQ,aACR,QAAS,YACT,OAAQ,YACR,OAAQ,WACR,MAAO,yBACP,OAAQ,yBACR,MAAO,yBACP,OAAQ,WACR,MAAO,gBACP,QAAS,YACT,OAAQ,YACR,OAAQ,gBAGR,OAAQ,aACR,QAAS,aACT,OAAQ,YACR,OAAQ,YACR,QAAS,aACT,OAAQ,eACR,OAAQ,YACR,QAAS,aACT,OAAQ,aAGR,OAAQ,kBACR,OAAQ,qBACR,QAAS,0EACT,OAAQ,2BACR,QAAS,oEACT,OAAQ,gCACR,QAAS,4EAGT,OAAQ,kBACR,MAAO,mBACP,OAAQ,oBACR,OAAQ,sBACR,MAAO,8BAGP,OAAQ,aACR,OAAQ,YACR,OAAQ,YACR,OAAQ,YAGR,OAAQ,YACR,QAAS,aACT,OAAQ,kBACR,OAAQ,kBAGR,QAAS,mBACT,OAAQ,2BACR,OAAQ,2BACR,OAAQ,2BACR,MAAO,2BACP,SAAU,0BACZ,EAKM,GAAkB,IAAI,IAAI,CAC9B,mBACA,kBACA,yBACA,yBACA,aACA,YACA,WACA,WACA,WACA,gBACA,YACA,eACF,CAAC,EAeM,SAAS,EAAa,CAAC,EAA0B,CACtD,IAAM,EAAM,GAAQ,CAAQ,EAAE,YAAY,EAC1C,OAAO,EAAmB,IAAQ,2BAgB7B,SAAS,EAAgB,CAAC,EAA2B,CAE1D,GAAI,EAAS,WAAW,OAAO,EAC7B,MAAO,GAGT,GAAI,GAAgB,IAAI,CAAQ,EAC9B,MAAO,GAGT,MAAO,GAOT,SAAS,CAAU,CAAC,EAAmB,CACrC,OAAO,EAAE,SAAS,IAAI,EAAI,KAAO,IAGnC,SAAS,CAAU,CAAC,EAAqB,CACvC,OAAO,EAAE,MAAM,QAAQ,EAAE,OAAO,OAAO,EAGzC,SAAS,EAAc,CAAC,EAAoB,CAC1C,GAAI,EAAE,WAAW,GAAG,GAAK,EAAE,WAAW,IAAI,EAAG,MAAO,GAEpD,GAAI,kBAAkB,KAAK,CAAC,EAAG,MAAO,GAEtC,GAAI,EAAE,WAAW,MAAM,EAAG,MAAO,GACjC,MAAO,GAGT,SAAS,CAAa,CAAC,EAAa,EAAyB,CAC3D,IAAM,EAAgB,CAAC,EACvB,QAAW,KAAQ,EAAO,CACxB,GAAI,CAAC,GAAQ,IAAS,IAAK,SAC3B,GAAI,IAAS,KAAM,CACjB,EAAI,IAAI,EACR,SAEF,EAAI,KAAK,CAAI,EAEf,OAAQ,IAAQ,KAAO,KAAO,KAAO,EAAI,KAAK,CAAG,EAGnD,SAAS,EAAW,CAAC,EAAkB,EAA8B,CACnE,IAAM,EAAM,EAAW,CAAQ,EAEzB,EAAc,cAAc,KAAK,CAAQ,EAEzC,EADiB,EAAS,MAAM,oBAAoB,IAC3B,GAEzB,EAAY,EAAW,CAAQ,EAC/B,EAAW,EAAW,CAAY,EAExC,GAAI,EAAO,CACT,IAAM,EAAa,EAAc,EAAK,CAAC,GAAG,EAAU,MAAM,CAAC,EAAG,GAAG,CAAQ,CAAC,EAC1E,MAAO,GAAG,IAAQ,IAGpB,GAAI,EAAa,CACf,IAAM,EAAa,EAAc,EAAK,CAAQ,EAC9C,MAAO,GAAG,IAAW,IAGvB,OAAO,EAAc,EAAK,CAAC,GAAG,EAAW,GAAG,CAAQ,CAAC,EAGvD,SAAS,EAAa,CAAC,EAA0B,CAC/C,GAAI,IAAa,GAAI,MAAO,IAC5B,IAAM,EAAM,EAAW,CAAQ,EAEzB,EADa,EAAS,MAAM,oBAAoB,IAC3B,GACrB,EAAQ,EAAW,CAAQ,EACjC,GAAI,EAAO,CACT,IAAM,EAAa,EAAc,EAAK,EAAM,MAAM,CAAC,CAAC,EACpD,MAAO,GAAG,IAAQ,IAEpB,OAAO,EAAc,EAAK,CAAK,EAGjC,SAAS,EAAO,CAAC,EAAmB,CAClC,IAAM,EAAO,GAAS,CAAC,EACjB,EAAM,EAAK,YAAY,GAAG,EAChC,GAAI,GAAO,EAAG,MAAO,GACrB,OAAO,EAAK,MAAM,CAAG,EAGvB,SAAS,EAAQ,CAAC,EAAmB,CACnC,IAAM,EAAQ,EAAE,MAAM,OAAO,EAE7B,OADa,EAAM,EAAM,OAAS,IACnB,GAuBV,SAAS,EAAgB,CAAC,EAAkB,EAA0B,CAE3E,GAAI,GAAe,CAAQ,EACzB,MAAU,MAAM,+BAA+B,GAAU,EAI3D,IAAM,EAAW,GAAY,EAAU,CAAQ,EACzC,EAAiB,GAAc,CAAQ,EACvC,EAAM,EAAW,CAAc,EAIrC,GAAI,IAAa,GAAkB,CAAC,EAAS,WAAW,EAAiB,CAAG,EAC1E,MAAU,MAAM,gCAAgC,GAAU,EAG5D,OAAO,EA6BT,eAAsB,CAAY,CAChC,EACA,EAA6B,CAAC,EACT,CACrB,IAAM,EACJ,EAAQ,UACR,EAAQ,IAAI,IAAI,GACf,WAA+D,SAAS,MAAM,GAC/E,IAGI,EAAe,GAAiB,EAAU,CAAQ,EAGlD,EAAW,GAAc,CAAQ,EACjC,EAAW,GAAiB,CAAQ,EAEtC,EAEJ,GAAI,EAAQ,GAAI,CAEd,GAAI,CADW,MAAM,EAAQ,GAAG,OAAO,CAAY,EAEjD,MAAU,MAAM,mBAAmB,GAAU,EAE/C,EAAU,EACN,MAAM,EAAQ,GAAG,WAAW,CAAY,EACxC,MAAM,EAAQ,GAAG,SAAS,CAAY,EACrC,QAAI,OAAQ,WAAuC,IAAW,IAAa,CAShF,IAAM,EADO,WAA6C,IACzC,KAAK,CAAY,EAElC,GAAI,CADW,MAAM,EAAK,OAAO,EAE/B,MAAU,MAAM,mBAAmB,GAAU,EAE/C,EAAU,EAAW,MAAM,EAAK,YAAY,EAAI,MAAM,EAAK,KAAK,EAEhE,WAAU,MACR,oFACF,EAGF,MAAO,CACL,UACA,WACA,UACF,ECjVK,SAAS,CAAa,CAAC,EAA8B,CAC1D,OAAO,EAAO,KAAK,CAAC,IAAU,EAAM,MAAM,EAyB5C,eAAsB,CAAa,CACjC,EACA,EAAgC,CAAC,EACd,CACnB,IAAM,EAAO,IAAI,SACX,EACJ,EAAQ,UACR,EAAQ,IAAI,IAAI,GACf,WAA+D,SAAS,MAAM,GAC/E,IAEF,QAAW,KAAS,EAClB,GAAI,EAAM,QAAU,EAAM,KAAM,CAE9B,IAAM,EAAa,MAAM,EACvB,EAAM,KACN,EAAQ,GAAK,CAAE,WAAU,GAAI,EAAQ,EAAG,EAAI,CAAE,UAAS,CACzD,EAGM,EACJ,EAAM,UAAY,EAAQ,IAAI,KAAK,SAAS,EAAM,IAAI,GAAK,GAAS,EAAM,IAAI,EAG1E,EAAO,IAAI,KAAK,CAAC,EAAW,OAAO,EAAG,CAAE,KAAM,EAAW,QAAS,CAAC,EAGzE,EAAK,OAAO,EAAM,KAAM,EAAM,CAAQ,EAGtC,OAAK,OAAO,EAAM,KAAM,EAAM,KAAK,EAIvC,OAAO,EAGT,SAAS,EAAQ,CAAC,EAAmB,CACnC,IAAM,EAAQ,EAAE,MAAM,OAAO,EAE7B,OADa,EAAM,EAAM,OAAS,IACnB,GAuBV,SAAS,CAAe,CAAC,EAAsC,CACpE,IAAM,EAAS,IAAI,gBAEnB,QAAW,KAAS,EAAQ,CAE1B,GAAI,EAAM,OACR,SAEF,EAAO,OAAO,EAAM,KAAM,EAAM,KAAK,EAGvC,OAAO,EChIT,SAAS,EAAM,CAAC,EAAoB,CAClC,MAAO,kBAAkB,KAAK,CAAC,EAGjC,SAAS,CAAa,CAAC,EAA+B,CACpD,IAAM,EAAwB,CAAC,EAC3B,EAAI,EACJ,EAAY,EAEhB,MAAO,EAAI,EAAM,OAAQ,CACvB,IAAM,EAAI,EAAM,GACV,EAAI,EAAM,EAAI,GAEpB,GAAI,IAAM,KAAO,IAAM,IAAK,CAC1B,GAAI,EAAI,EACN,EAAM,KAAK,CAAE,KAAM,OAAQ,MAAO,EAAM,MAAM,EAAW,CAAC,CAAE,CAAC,EAG/D,IAAM,EAAQ,EACd,GAAK,EAEL,IAAI,EAAQ,EACR,EAAO,GAEX,MAAO,EAAI,EAAM,OAAQ,CACvB,IAAM,EAAK,EAAM,GACX,EAAK,EAAM,EAAI,GAErB,GAAI,IAAO,KAAO,IAAO,IAAK,CAC5B,IACA,GAAQ,KACR,GAAK,EACL,SAGF,GAAI,IAAO,KAAO,IAAO,IAAK,CAE5B,GADA,IACI,IAAU,EAAG,CACf,GAAK,EACL,MAEF,GAAQ,KACR,GAAK,EACL,SAGF,GAAQ,EACR,IAGF,GAAI,IAAU,EACZ,MAAU,MAAM,0CAA0C,EAG5D,IAAM,EAAM,EAAM,MAAM,EAAO,CAAC,EAChC,EAAM,KAAK,CAAE,KAAM,OAAQ,WAAY,EAAM,KAAI,CAAC,EAClD,EAAY,EACZ,SAGF,IAGF,GAAI,EAAY,EAAM,OACpB,EAAM,KAAK,CAAE,KAAM,OAAQ,MAAO,EAAM,MAAM,CAAS,CAAE,CAAC,EAG5D,OAAO,EAMT,SAAS,CAAc,CAAC,EAA8B,EAAuB,CAC3E,IAAM,EAAQ,EAAK,MAAM,GAAG,EACxB,EAAmB,EAEvB,QAAW,KAAQ,EAAO,CACxB,GAAI,IAAY,MAAQ,IAAY,OAClC,OAEF,GAAI,OAAO,IAAY,SACrB,OAEF,EAAW,EAAoC,GAGjD,OAAO,EAGT,SAAS,CAAiB,CAAC,EAAqE,CAC9F,IAAM,EAAU,EAAW,KAAK,EAChC,GAAI,CAAC,EAAQ,WAAW,GAAG,EAAG,OAAO,KACrC,GAAI,CAAC,EAAQ,SAAS,GAAG,EAAG,OAAO,KAEnC,IAAM,EAAU,EAAQ,QAAQ,GAAG,EACnC,GAAI,IAAY,GAAI,OAAO,KAE3B,IAAM,EAAO,EAAQ,MAAM,EAAG,CAAO,EAAE,KAAK,EAC5C,GAAI,CAAC,GAAQ,CAAC,GAAO,CAAI,EAAG,OAAO,KAEnC,IAAM,EAAU,EAAQ,MAAM,EAAU,EAAG,EAAE,EAC7C,MAAO,CAAE,YAAa,IAAI,IAAQ,SAAQ,EAG5C,SAAS,EAAwB,CAC/B,EACA,EACA,EACQ,CACR,IAAM,EAAQ,EAAc,CAAG,EAC/B,GAAI,EAAM,SAAW,GAAK,EAAM,IAAI,OAAS,OAAQ,OAAO,EAE5D,IAAI,EAAM,GACV,QAAW,KAAQ,EAAO,CACxB,GAAI,EAAK,OAAS,OAAQ,CACxB,GAAO,EAAK,MACZ,SAGF,IAAM,EAAO,EAAK,WAAW,KAAK,EAClC,GAAI,EAAkB,CAAI,EACxB,MAAU,MAAM,wDAAwD,EAAK,KAAK,EAGpF,IAAM,EAAQ,EAAe,EAAW,CAAI,EAC5C,GAAI,IAAU,OAAW,CACvB,GAAI,IAAsB,QACxB,MAAU,MAAM,uBAAuB,GAAM,EAE/C,GAAO,IAAsB,OAAS,EAAK,IAAM,GACjD,SAGF,GAAO,OAAO,CAAK,EAGrB,OAAO,EAGT,SAAS,CAAyB,CAChC,EACA,EACA,EACU,CACV,IAAM,EAAe,GAAyB,EAAS,EAAW,CAAiB,EAAE,KAAK,EAC1F,GAAI,CAAC,EAAc,MAAO,CAAC,EAE3B,GAAI,CACF,IAAM,EAAS,KAAK,MAAM,CAAY,EACtC,GAAI,MAAM,QAAQ,CAAM,EACtB,OAAO,EAAO,IAAI,CAAC,IAAM,OAAO,CAAC,CAAC,EAEpC,KAAM,EAIR,MAAO,CAAC,CAAY,EAMtB,SAAS,EAAiB,CACxB,EACA,EACA,EAA8B,CAAC,EACvB,CACR,IAAQ,YAAY,CAAC,EAAG,oBAAoB,SAAY,EAElD,EAAQ,EAAc,CAAG,EAC/B,GAAI,EAAM,SAAW,GAAK,EAAM,IAAI,OAAS,OAAQ,OAAO,EAE5D,IAAI,EAAM,GACV,QAAW,KAAQ,EAAO,CACxB,GAAI,EAAK,OAAS,OAAQ,CACxB,GAAO,EAAK,MACZ,SAGF,IAAM,EAAS,EAAkB,EAAK,UAAU,EAChD,GAAI,EAAQ,CACV,IAAM,EAAW,EAAU,EAAO,aAClC,GAAI,EAAU,CACZ,IAAM,EAAO,EAA0B,EAAO,QAAS,EAAW,CAAiB,EAC7E,EAAS,EAAS,GAAG,CAAI,EAC/B,GAAI,aAAkB,QACpB,MAAU,MACR,YAAY,EAAO,+EACrB,EAEF,GAAO,OAAO,CAAM,EACpB,SAGF,GAAI,IAAsB,QACxB,MAAU,MAAM,qBAAqB,EAAO,aAAa,EAE3D,GAAO,IAAsB,OAAS,EAAK,IAAM,GACjD,SAGF,IAAM,EAAO,EAAK,WAAW,KAAK,EAC5B,EAAQ,EAAe,EAAW,CAAI,EAC5C,GAAI,IAAU,OAAW,CACvB,GAAI,IAAsB,QACxB,MAAU,MAAM,uBAAuB,GAAM,EAE/C,GAAO,IAAsB,OAAS,EAAK,IAAM,GACjD,SAGF,GAAO,OAAO,CAAK,EAGrB,OAAO,EAMT,eAAe,EAAsB,CACnC,EACA,EACA,EAA8B,CAAC,EACd,CACjB,IAAQ,YAAY,CAAC,EAAG,oBAAoB,SAAY,EAClD,EAAQ,EAAc,CAAG,EAC/B,GAAI,EAAM,SAAW,GAAK,EAAM,IAAI,OAAS,OAAQ,OAAO,EAE5D,IAAI,EAAM,GACV,QAAW,KAAQ,EAAO,CACxB,GAAI,EAAK,OAAS,OAAQ,CACxB,GAAO,EAAK,MACZ,SAGF,IAAM,EAAS,EAAkB,EAAK,UAAU,EAChD,GAAI,EAAQ,CACV,IAAM,EAAW,EAAU,EAAO,aAClC,GAAI,EAAU,CACZ,IAAM,EAAO,EAA0B,EAAO,QAAS,EAAW,CAAiB,EAC7E,EAAS,MAAM,EAAS,GAAG,CAAI,EACrC,GAAO,OAAO,CAAM,EACpB,SAGF,GAAI,IAAsB,QACxB,MAAU,MAAM,qBAAqB,EAAO,aAAa,EAE3D,GAAO,IAAsB,OAAS,EAAK,IAAM,GACjD,SAGF,IAAM,EAAO,EAAK,WAAW,KAAK,EAC5B,EAAQ,EAAe,EAAW,CAAI,EAC5C,GAAI,IAAU,OAAW,CACvB,GAAI,IAAsB,QACxB,MAAU,MAAM,uBAAuB,GAAM,EAE/C,GAAO,IAAsB,OAAS,EAAK,IAAM,GACjD,SAGF,GAAO,OAAO,CAAK,EAGrB,OAAO,EAMT,SAAS,CAAmB,CAC1B,EACA,EACA,EACG,CACH,GAAI,OAAO,IAAU,SACnB,OAAO,GAAkB,EAAO,EAAW,CAAO,EAGpD,GAAI,MAAM,QAAQ,CAAK,EACrB,OAAO,EAAM,IAAI,CAAC,IAAS,EAAiB,EAAM,EAAW,CAAO,CAAC,EAGvE,GAAI,IAAU,MAAQ,OAAO,IAAU,SAAU,CAC/C,IAAM,EAAkC,CAAC,EACzC,QAAY,EAAK,KAAQ,OAAO,QAAQ,CAAgC,EACtE,EAAO,GAAO,EAAiB,EAAK,EAAW,CAAO,EAExD,OAAO,EAGT,OAAO,EAMT,eAAe,CAAwB,CACrC,EACA,EACA,EACY,CACZ,GAAI,OAAO,IAAU,SACnB,OAAQ,MAAM,GAAuB,EAAO,EAAW,CAAO,EAGhE,GAAI,MAAM,QAAQ,CAAK,EACrB,OAAQ,MAAM,QAAQ,IACpB,EAAM,IAAI,CAAC,IAAS,EAAsB,EAAM,EAAW,CAAO,CAAC,CACrE,EAGF,GAAI,IAAU,MAAQ,OAAO,IAAU,SAAU,CAC/C,IAAM,EAAkC,CAAC,EACnC,EAAU,OAAO,QAAQ,CAAgC,EACzD,EAAkB,MAAM,QAAQ,IACpC,EAAQ,IAAI,OAAQ,EAAK,KAAS,CAAC,EAAK,MAAM,EAAsB,EAAK,EAAW,CAAO,CAAC,CAAC,CAC/F,EACA,QAAY,EAAK,KAAQ,EACvB,EAAO,GAAiB,EAE1B,OAAO,EAGT,OAAO,EAOF,SAAS,EAAc,CAC5B,EACA,EACA,EAA8B,CAAC,EAC5B,CACH,OAAO,EAAiB,EAAQ,EAAW,CAAO,EAM7C,SAAS,CAAkB,CAAC,EAA8B,CAAC,EAAiB,CACjF,MAAO,MACC,YAAc,CAAC,EAAW,EAAgD,CAC9E,OAAO,EAAsB,EAAQ,EAAW,CAAO,EAE3D,EC/VF,IAAM,EAAoB,wBAa1B,SAAS,EAAU,CAAC,EAAc,EAA+B,CAE/D,GACE,GACA,CAAC,EAAY,SAAS,WAAW,GACjC,CAAC,EAAY,SAAS,uBAAuB,EAE7C,MAAO,GAIT,IAAM,EAAQ,EAAK,MAAM,OAAO,EAAE,OAAO,CAAC,IAAM,EAAE,KAAK,CAAC,EACxD,GAAI,EAAM,SAAW,EAAG,MAAO,GAG/B,GAAI,EAAM,SAAW,GAAK,EAAM,IAAI,SAAS,GAAG,EAC9C,MAAO,GAIT,OAAO,EAAM,MAAM,CAAC,IAAS,EAAkB,KAAK,CAAI,CAAC,EAM3D,SAAS,EAAa,CAAC,EAA2B,CAChD,IAAM,EAAsB,CAAC,EACvB,EAAQ,EAAK,MAAM,OAAO,EAAE,OAAO,CAAC,IAAM,EAAE,KAAK,CAAC,EAExD,QAAW,KAAQ,EAAO,CACxB,IAAM,EAAQ,EAAK,MAAM,CAAiB,EAC1C,GAAI,CAAC,EAAO,SAEZ,IAAM,EAAU,EAAM,GAChB,EAAW,EAAM,GACvB,GAAI,CAAC,EAAS,SAEd,IAAM,EAAO,EAAQ,KAAK,EACtB,GAAS,GAAY,IAAI,KAAK,EAKlC,GAFe,EAAM,WAAW,KAAK,GAAK,EAAM,WAAW,KAAK,EAEpD,CAEV,EAAQ,EAAM,MAAM,CAAC,EAGrB,IAAI,EAAW,EACX,EAEE,EAAY,EAAM,QAAQ,KAAK,EACrC,GAAI,IAAc,GAChB,EAAW,EAAM,MAAM,EAAG,CAAS,EAAE,KAAK,EAC1C,EAAW,EAAM,MAAM,EAAY,CAAC,EAAE,KAAK,EAG7C,EAAO,KACL,EAAuB,CACrB,OACA,MAAO,GACP,OAAQ,GACR,KAAM,CACR,CAAC,EACE,UAAU,WAAY,CAAQ,EAC9B,MAAM,CACX,EAEA,OAAO,KAAK,CAAE,OAAM,QAAO,OAAQ,EAAM,CAAC,EAI9C,OAAO,EAMF,SAAS,CAAK,CAAC,EAAkC,CACtD,IAAM,EAA4B,CAAC,EAK7B,EAAQ,EAAQ,MAAM,OAAO,EAC7B,EAAoD,CAAC,EACvD,EAAmD,CAAE,MAAO,CAAC,CAAE,EAEnE,QAAW,KAAQ,EAAO,CACxB,IAAM,EAAiB,EAAK,MAAM,cAAc,EAChD,GAAI,EAAgB,CAElB,GAAI,EAAa,MAAM,OAAS,GAAK,EAAO,SAAW,EACrD,EAAO,KAAK,CAAY,EAG1B,IAAM,EAAY,EAAe,IAAI,KAAK,EAC1C,EAAe,EAAgD,CAAE,MAAO,CAAC,CAAE,CAAC,EACzE,UAAU,OAAQ,GAAa,MAAS,EACxC,MAAM,EAET,OAAa,MAAM,KAAK,CAAI,EAKhC,EAAO,KAAK,CAAY,EAGxB,QAAW,KAAS,EAAQ,CAC1B,GAAI,EAAM,MAAM,SAAW,GAAK,CAAC,EAAM,KACrC,SAGF,IAAM,EAAe,EAAM,MAAM,KAAK;AAAA,CAAI,EACpC,EAAU,GAAkB,EAAc,EAAM,IAAI,EAC1D,GAAI,EACF,EAAS,KAAK,CAAO,EAIzB,OAAO,EAMT,SAAS,EAAiB,CAAC,EAAe,EAA4C,CACpF,IAAM,EAAQ,EAAM,MAAM,OAAO,EAC3B,EAA+B,CAAC,EAClC,EAAO,EACP,EAAS,GACT,EAAM,GACJ,EAAkC,CAAC,EACrC,EACA,EACA,EACA,EAAS,GACP,EAAsB,CAAC,EACzB,EAAmB,GAEvB,QAAS,EAAI,EAAG,EAAI,EAAM,OAAQ,IAAK,CACrC,IAAM,EAAO,EAAM,GACnB,GAAI,IAAS,OAAW,SACxB,IAAM,EAAc,EAAK,KAAK,EAG9B,GAAI,CAAC,GAAoB,IAAgB,GACvC,SAIF,GAAI,CAAC,IAAqB,EAAY,WAAW,GAAG,GAAK,EAAY,WAAW,IAAI,GAAI,CAItF,IAAM,EAHiB,EAAY,QAAQ,eAAgB,EAAE,EAGvB,MAAM,kBAAkB,EAC9D,GAAI,EAAgB,CAClB,KAAS,EAAW,GAAS,EAC7B,GAAI,IAAc,OAChB,EAAO,GAAO,KAAK,GAAK,EACnB,QAAI,EACT,EAAK,GAAa,GAAO,KAAK,GAAK,GAGvC,SAIF,GAAI,CAAC,EAAkB,CACrB,IAAM,EAAmB,EAAY,MACnC,qFACF,EACA,GAAI,EAAkB,CACpB,IAAM,EAAc,EAAiB,GAC/B,EAAW,EAAiB,GAClC,GAAI,CAAC,GAAe,CAAC,EAAU,SAC/B,EAAS,EAAY,YAAY,EACjC,EAAM,EACN,EAAmB,GACnB,SAIF,IAAM,EAAqB,EAAY,MACrC,kEACF,EACA,GAAI,EAAoB,CACtB,IAAM,EAAc,EAAmB,GACjC,EAAW,EAAmB,GACpC,GAAI,CAAC,GAAe,CAAC,EAAU,SAC/B,EAAS,EAAY,YAAY,EACjC,EAAM,EAAS,KAAK,EACpB,EAAmB,GACnB,SAIF,SAIF,GAAI,EACF,EAAU,KAAK,CAAI,EACd,QAAI,IAAgB,GAEzB,EAAS,GACJ,KAEL,IAAM,EAAc,EAAK,MAAM,mBAAmB,EAClD,GAAI,EAAa,CACf,IAAM,EAAa,EAAY,GAC/B,GAAI,CAAC,EAAY,SACjB,IAAM,EAAc,EAAY,IAAM,GACtC,EAAQ,EAAW,KAAK,GAAK,EAAY,KAAK,IAMpD,GAAI,CAAC,GAAU,CAAC,EACd,OAAO,KAIT,GAAI,EAAU,OAAS,EAAG,CAExB,MAAO,EAAU,OAAS,GAAK,EAAU,EAAU,OAAS,IAAI,KAAK,IAAM,GACzE,EAAU,IAAI,EAIhB,GAAI,EAAU,SAAW,EAAG,CAC1B,IAAM,EAAe,EAAU,IAAI,KAAK,EAAE,MAAM,YAAY,EAC5D,GAAI,EAAc,CAChB,IAAM,EAAW,EAAa,GAC9B,GAAI,EACF,EAAW,CAAE,KAAM,CAAS,EAEzB,QAAI,EAAU,IAAI,KAAK,EAC5B,EAAO,EAAU,GAEd,QAAI,EAAU,OAAS,EAC5B,EAAO,EAAU,KAAK;AAAA,CAAI,EAM9B,IAAM,EAAc,EAAQ,iBAAmB,EAAQ,gBAEvD,GAAI,GAAQ,GAAW,EAAM,CAAW,EACtC,EAAW,GAAc,CAAI,EAC7B,EAAO,OAGT,OAAO,EAA2B,CAChC,SACA,MACA,UACA,IAAK,EACL,MACF,CAAC,EACE,UAAU,OAAQ,CAAI,EACtB,UAAU,OAAQ,CAAI,EACtB,UAAU,WAAY,CAAQ,EAC9B,UAAU,WAAY,CAAQ,EAC9B,MAAM,EAMX,eAAsB,EAAS,CAAC,EAAwC,CACtE,OAAO,MAAM,EAAgB,CAAI,EAOnC,eAAsB,CAAe,CAAC,EAAc,EAAmC,CACrF,GAAI,EAAI,CACN,IAAM,EAAU,MAAM,EAAG,SAAS,CAAI,EACtC,OAAO,EAAM,CAAO,EAGtB,GAAI,OAAQ,WAAuC,IAAW,IAAa,CAMzE,IAAM,EAAU,MAFH,WAA6C,IACzC,KAAK,CAAI,EACC,KAAK,EAChC,OAAO,EAAM,CAAO,EAGtB,MAAU,MAAM,wEAAwE,ECzR1F,SAAS,CAAI,CAAC,EAAgC,EAA0B,CACtE,IAAU,CAAK,EAGjB,SAAS,CAAe,CAAC,EAAU,EAAgB,CACjD,IAAM,EAAQ,EAAI,GAClB,GAAI,CAAC,EACH,MAAU,MAAM,CAAG,EAErB,OAAO,EAGT,SAAS,EAAe,CAAC,EAAmB,CAC1C,IAAM,EAAM,KAAK,IAAI,EAAE,YAAY,GAAG,EAAG,EAAE,YAAY,IAAI,CAAC,EAC5D,GAAI,IAAQ,GAAI,MAAO,IACvB,OAAO,IAAQ,EAAI,EAAE,MAAM,EAAG,CAAC,EAAI,EAAE,MAAM,EAAG,CAAG,EAGnD,SAAS,EAAc,CAAC,EAAoB,CAC1C,GAAI,EAAE,WAAW,GAAG,GAAK,EAAE,WAAW,IAAI,EAAG,MAAO,GACpD,GAAI,kBAAkB,KAAK,CAAC,EAAG,MAAO,GACtC,GAAI,EAAE,WAAW,MAAM,EAAG,MAAO,GACjC,MAAO,GAGT,SAAS,EAAW,CAAC,EAAW,EAAmB,CACjD,GAAI,CAAC,EAAG,OAAO,EACf,GAAI,CAAC,EAAG,OAAO,EACf,IAAM,EAAM,EAAE,SAAS,IAAI,EAAI,KAAO,IAChC,EAAQ,EAAE,SAAS,GAAG,GAAK,EAAE,SAAS,IAAI,EAAI,EAAE,MAAM,EAAG,EAAE,EAAI,EAC/D,EAAQ,EAAE,WAAW,GAAG,GAAK,EAAE,WAAW,IAAI,EAAI,EAAE,MAAM,CAAC,EAAI,EACrE,MAAO,GAAG,IAAQ,IAAM,IAG1B,SAAS,EAAe,CAAC,EAAkB,EAAiB,CAC1D,GAAI,EACF,OAAO,EAAG,KAAK,QAAQ,EAAG,KAAK,QAAQ,CAAQ,CAAC,EAGlD,IAAM,EACH,WAA+D,SAAS,MAAM,GAAK,IAChF,EAAW,GAAe,CAAQ,EAAI,EAAW,GAAY,EAAK,CAAQ,EAChF,OAAO,GAAgB,CAAQ,EAGjC,SAAS,EAAgB,CACvB,EACA,EACwB,CACxB,GAAI,CAAC,EAAQ,OAAO,EACpB,IAAM,EAAW,EAAQ,QAAa,EAAQ,QAAa,GAC3D,MAAO,IACF,EACH,OAAQ,EAAW,GAAG,MAAa,IAAW,CAChD,EAGK,SAAS,EAAY,CAAC,EAAuB,CAAC,EAAW,CAC9D,IAAM,EAAY,EAAO,WAAa,EAAoB,EACpD,EAAK,EAAO,GACZ,EAAc,EAAO,YACrB,EAAU,EAAO,QACjB,EAAiB,EAAO,eAExB,EAAe,EAAmB,CAAE,UAAW,EAAO,WAAa,CAAC,CAAE,CAAC,EAE7E,eAAe,CAAiB,CAC9B,EACA,EAIC,CACD,EAAK,EAAS,CAAE,KAAM,eAAgB,OAAQ,QAAS,CAAC,EACxD,IAAM,EAAW,EAAM,CAAQ,EAC/B,EAAK,EAAS,CAAE,KAAM,gBAAiB,OAAQ,SAAU,aAAc,EAAS,MAAO,CAAC,EAExF,IAAM,EAAU,EAAa,EAAU,8CAA8C,EAErF,EAAK,EAAS,CAAE,KAAM,oBAAqB,CAAC,EAC5C,IAAM,EAAa,IAAM,EAAQ,WAAa,CAAC,CAAG,EAC5C,EAAe,MAAM,EAAa,YAAY,EAAS,CAAU,EACvE,EAAK,EAAS,CAAE,KAAM,qBAAsB,CAAC,EAE7C,EAAK,EAAS,CAAE,KAAM,gBAAiB,CAAC,EACxC,IAAM,EACJ,EAAQ,UACR,GAAI,IAAI,GACP,WAA+D,SAAS,MAAM,GAC/E,KAEM,kBAAmB,MAAM,EAC/B,EACA,EAAoF,CAClF,UACF,CAAC,EACE,UAAU,KAAM,CAAE,EAClB,UAAU,iBAAkB,CAAc,EAC1C,MAAM,CACX,EAGA,OAFA,EAAK,EAAS,CAAE,KAAM,iBAAkB,CAAC,EAElC,CAAE,iBAAgB,QAAS,EAAa,GAAI,EAGrD,eAAe,CAAe,CAC5B,EACA,EAIC,CACD,EAAK,EAAS,CAAE,KAAM,eAAgB,OAAQ,MAAO,CAAC,EACtD,IAAM,EAAW,MAAM,EAAgB,EAAM,CAAE,EAC/C,EAAK,EAAS,CAAE,KAAM,gBAAiB,OAAQ,OAAQ,aAAc,EAAS,MAAO,CAAC,EAEtF,IAAM,EAAU,EAAa,EAAU,oCAAoC,GAAM,EAEjF,EAAK,EAAS,CAAE,KAAM,oBAAqB,CAAC,EAC5C,IAAM,EAAa,IAAM,EAAQ,WAAa,CAAC,CAAG,EAC5C,EAAe,MAAM,EAAa,YAAY,EAAS,CAAU,EACvE,EAAK,EAAS,CAAE,KAAM,qBAAsB,CAAC,EAE7C,EAAK,EAAS,CAAE,KAAM,gBAAiB,CAAC,EACxC,IAAM,EAAW,GAAgB,EAAM,CAAE,GACjC,kBAAmB,MAAM,EAC/B,EACA,EAAoF,CAClF,UACF,CAAC,EACE,UAAU,KAAM,CAAE,EAClB,UAAU,iBAAkB,CAAc,EAC1C,MAAM,CACX,EAGA,OAFA,EAAK,EAAS,CAAE,KAAM,iBAAkB,CAAC,EAElC,CAAE,iBAAgB,QAAS,EAAa,GAAI,EAGrD,eAAe,CAAW,CACxB,EACA,EACA,EACmB,CACnB,IAAM,EAAU,EAAe,SAAW,CAAC,EAErC,EAAe,EAAc,MAAM,EAAY,gBAAgB,CAAa,EAAI,OAChF,EAAqB,EAAc,GAAiB,EAAS,CAAY,EAAI,EAE7E,EAAqC,IACtC,EACH,QAAS,CACX,EAEA,EAAK,EAAS,CAAE,KAAM,eAAgB,OAAQ,EAAmB,OAAQ,IAAK,CAAc,CAAC,EAE7F,GAAI,CACF,IAAM,EAAc,EAA4B,CAAC,CAAC,EAC/C,UAAU,UAAW,EAAQ,SAAS,EACtC,UAAU,SAAU,EAAQ,MAAM,EAClC,UAAU,kBAAmB,EAAQ,eAAe,EACpD,UAAU,cAAe,EAAQ,WAAW,EAC5C,UAAU,QAAS,EAAQ,KAAK,EAChC,MAAM,EAEH,EAAW,MAAM,EAAqB,EAAoB,EAAa,CAAS,EAStF,GAPA,EAAK,EAAS,CACZ,KAAM,gBACN,OAAQ,EAAmB,OAC3B,IAAK,EACL,OAAQ,EAAS,MACnB,CAAC,EAEG,EACF,MAAM,EAAY,gBAAgB,EAAe,CAAQ,EAG3D,OAAO,EACP,MAAO,EAAG,CAMV,MALA,EAAK,EAAS,CACZ,KAAM,QACN,MAAO,QACP,QAAS,aAAa,MAAQ,EAAE,QAAU,OAAO,CAAC,CACpD,CAAC,EACK,GAIV,MAAO,CACL,YAAa,OACP,UAAS,CAAC,EAAU,EAAU,CAAC,EAAG,CACtC,IAAQ,iBAAgB,WAAY,MAAM,EAAkB,EAAU,CAAO,EAC7E,OAAO,MAAM,EAAY,EAAgB,EAAS,CAAO,QAErD,QAAO,CAAC,EAAM,EAAU,CAAC,EAAG,CAChC,IAAQ,iBAAgB,WAAY,MAAM,EAAgB,EAAM,CAAO,EACvE,OAAO,MAAM,EAAY,EAAgB,EAAS,CAAO,EAE7D,EAGF,eAAe,CAAqB,CAClC,EAQA,EAC6C,CAC7C,IAAM,EAAkC,IAClC,EAAI,gBAAkB,CAAC,KACvB,EAAa,SAAW,CAAC,CAC/B,EAEI,EAA+B,EAAa,KAEhD,GAAI,EAAa,SAAU,CACzB,IAAM,EAAa,MAAM,EACvB,EAAa,SAAS,KACtB,EAA2C,CAAE,SAAU,EAAI,QAAS,CAAC,EAClE,UAAU,KAAM,EAAI,EAAE,EACtB,MAAM,CACX,EAIA,GAFA,EAAO,EAAW,QAEd,CAAC,EAAQ,iBAAmB,CAAC,EAAQ,gBACvC,EAAQ,gBAAkB,EAAW,SAElC,QAAI,EAAa,UAAY,EAAa,SAAS,OAAS,GAGjE,GAFiB,EAAc,EAAa,QAAQ,EAGlD,EAAO,MAAM,EACX,EAAa,SACb,EAA2C,CAAE,SAAU,EAAI,QAAS,CAAC,EAClE,UAAU,KAAM,EAAI,EAAE,EACtB,MAAM,CACX,EACA,OAAO,EAAQ,gBACf,OAAO,EAAQ,gBAGf,QADA,EAAO,EAAgB,EAAa,QAAQ,EACxC,CAAC,EAAQ,iBAAmB,CAAC,EAAQ,gBACvC,EAAQ,gBAAkB,oCAYhC,MAAO,CAAE,eAP8B,CACrC,OAAQ,EAAa,OACrB,IAAK,EAAa,IAClB,aACI,IAAS,OAAY,CAAE,MAAK,EAAI,CAAC,CACvC,CAEwB",
16
+ "debugId": "A62DD58F669C6FF464756E2164756E21",
17
17
  "names": []
18
18
  }
package/dist/index.d.ts CHANGED
@@ -5,5 +5,6 @@ export { type BuildFormDataOptions, buildFormData, buildUrlEncoded, hasFileField
5
5
  export { createInterpolator, interpolate } from './interpolate';
6
6
  export { parse, parseFile, parseFileWithIO } from './parser';
7
7
  export { createAutoTransport, createFetchTransport } from './runtime';
8
+ export { getServerMetadata, type ServerMetadata } from './server-metadata';
8
9
  export type { Client, ClientConfig, ExecuteOptions, ExecuteRequest, FileReference, FormField, InterpolateOptions, Interpolator, ParsedRequest, Resolver, RunOptions } from './types';
9
10
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAExC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,OAAO,EACL,KAAK,iBAAiB,EACtB,aAAa,EACb,gBAAgB,EAChB,KAAK,UAAU,EACf,YAAY,EACZ,gBAAgB,EACjB,MAAM,eAAe,CAAC;AAEvB,OAAO,EACL,KAAK,oBAAoB,EACzB,aAAa,EACb,eAAe,EACf,aAAa,EACd,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAChE,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE7D,OAAO,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AAGtE,YAAY,EACV,MAAM,EACN,YAAY,EACZ,cAAc,EACd,cAAc,EACd,aAAa,EACb,SAAS,EACT,kBAAkB,EAClB,YAAY,EACZ,aAAa,EACb,QAAQ,EACR,UAAU,EACX,MAAM,SAAS,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAExC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,OAAO,EACL,KAAK,iBAAiB,EACtB,aAAa,EACb,gBAAgB,EAChB,KAAK,UAAU,EACf,YAAY,EACZ,gBAAgB,EACjB,MAAM,eAAe,CAAC;AAEvB,OAAO,EACL,KAAK,oBAAoB,EACzB,aAAa,EACb,eAAe,EACf,aAAa,EACd,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAChE,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE7D,OAAO,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AAEtE,OAAO,EAAE,iBAAiB,EAAE,KAAK,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAG3E,YAAY,EACV,MAAM,EACN,YAAY,EACZ,cAAc,EACd,cAAc,EACd,aAAa,EACb,SAAS,EACT,kBAAkB,EAClB,YAAY,EACZ,aAAa,EACb,QAAQ,EACR,UAAU,EACX,MAAM,SAAS,CAAC"}
package/dist/index.js CHANGED
@@ -1,6 +1,6 @@
1
- function c(K){throw Error(`${K} is not supported by this transport. Provide a transport that supports it.`)}function T(K=fetch){return{capabilities:{proxy:!1,validateSSL:!1},async fetch(Q,Z,$){if($.proxy)c("proxy");if($.validateSSL===!1)c("validateSSL=false");return await K(Q,Z)}}}function e(){return typeof globalThis.Bun<"u"}function M(){if(!e())return T(fetch);return{capabilities:{proxy:!0,validateSSL:!0},async fetch(K,Q,Z){let $={...Q??{}};if(Z.proxy!==void 0)$.proxy=Z.proxy;if(Z.validateSSL===!1)$.tls={rejectUnauthorized:!1};return await fetch(K,$)}}}import{access as KK,readFile as h}from"node:fs/promises";import*as F from"node:path";async function QK(K){try{return await KK(K),!0}catch{return!1}}function ZK(){return{cwd:()=>process.cwd(),path:{resolve:(...K)=>F.resolve(...K),dirname:(K)=>F.dirname(K),basename:(K)=>F.basename(K),extname:(K)=>F.extname(K),isAbsolute:(K)=>F.isAbsolute(K),sep:F.sep},exists:QK,readText:async(K)=>await h(K,"utf8"),readBinary:async(K)=>{let Q=await h(K);return Q.buffer.slice(Q.byteOffset,Q.byteOffset+Q.byteLength)}}}function w(K){let Q={...K},Z={when($,Y){if($)Q={...Q,...Y};return Z},ifDefined($,Y){if(Y!==void 0)Q={...Q,[$]:Y};return Z},build(){return Q}};return Z}function $K(K,Q){return Q!==void 0&&!["GET","HEAD"].includes(K.toUpperCase())}function YK(K,Q){let Z=$K(K.method,K.body)&&K.body!==void 0;return w({method:K.method,redirect:Q.followRedirects?"follow":"manual",signal:Q.signal}).ifDefined("headers",K.headers).ifDefined("body",Z?K.body:void 0).build()}function XK(K){if(K.provided)return{signal:K.provided,isInternalTimeout:!1,cleanup:()=>{}};let Q=new AbortController,Z=setTimeout(()=>Q.abort(),K.timeout);return{signal:Q.signal,isInternalTimeout:!0,cleanup:()=>clearTimeout(Z)}}function GK(K,Q){if(K instanceof Error&&K.name==="AbortError"){if(Q.isInternalTimeout)return Error(`Request timeout after ${Q.timeout}ms`)}return K instanceof Error?K:Error(String(K))}async function u(K,Q,Z){let $=Q.timeout??30000,Y=w({timeout:$}).ifDefined("provided",Q.signal).build(),{signal:X,isInternalTimeout:H,cleanup:U}=XK(Y),G=w({followRedirects:Q.followRedirects??!0,signal:X}).build(),z=YK(K,G);try{let W=w({}).ifDefined("proxy",Q.proxy).ifDefined("validateSSL",Q.validateSSL).build();return await Z.fetch(K.url,z,W)}catch(W){throw GK(W,{timeout:$,isInternalTimeout:H})}finally{U()}}var UK={".json":"application/json",".xml":"application/xml",".txt":"text/plain",".html":"text/html",".htm":"text/html",".css":"text/css",".js":"application/javascript",".mjs":"application/javascript",".ts":"application/typescript",".csv":"text/csv",".md":"text/markdown",".yaml":"text/yaml",".yml":"text/yaml",".svg":"image/svg+xml",".jpg":"image/jpeg",".jpeg":"image/jpeg",".png":"image/png",".gif":"image/gif",".webp":"image/webp",".ico":"image/x-icon",".bmp":"image/bmp",".tiff":"image/tiff",".tif":"image/tiff",".pdf":"application/pdf",".doc":"application/msword",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".xls":"application/vnd.ms-excel",".xlsx":"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",".ppt":"application/vnd.ms-powerpoint",".pptx":"application/vnd.openxmlformats-officedocument.presentationml.presentation",".zip":"application/zip",".gz":"application/gzip",".tar":"application/x-tar",".rar":"application/vnd.rar",".7z":"application/x-7z-compressed",".mp3":"audio/mpeg",".wav":"audio/wav",".ogg":"audio/ogg",".m4a":"audio/mp4",".mp4":"video/mp4",".webm":"video/webm",".avi":"video/x-msvideo",".mov":"video/quicktime",".wasm":"application/wasm",".bin":"application/octet-stream",".exe":"application/octet-stream",".dll":"application/octet-stream",".so":"application/octet-stream",".dylib":"application/octet-stream"},jK=new Set(["application/json","application/xml","application/javascript","application/typescript","text/plain","text/html","text/css","text/csv","text/xml","text/markdown","text/yaml","image/svg+xml"]);function d(K){let Q=zK(K).toLowerCase();return UK[Q]??"application/octet-stream"}function p(K){if(K.startsWith("text/"))return!1;if(jK.has(K))return!1;return!0}function x(K){return K.includes("\\")?"\\":"/"}function k(K){return K.split(/[\\/]+/).filter(Boolean)}function HK(K){if(K.startsWith("/")||K.startsWith("\\"))return!0;if(/^[A-Za-z]:[\\/]/.test(K))return!0;if(K.startsWith("\\\\"))return!0;return!1}function B(K,Q){let Z=[];for(let $ of Q){if(!$||$===".")continue;if($===".."){Z.pop();continue}Z.push($)}return(K==="\\"?"\\":"/")+Z.join(K)}function DK(K,Q){let Z=x(K),$=/^[A-Za-z]:$/.test(K),X=K.match(/^([A-Za-z]:)[\\/]?/)?.[1],H=k(K),U=k(Q);if(X){let G=B(Z,[...H.slice(1),...U]);return`${X}${G}`}if($){let G=B(Z,U);return`${K}${G}`}return B(Z,[...H,...U])}function WK(K){if(K==="")return"/";let Q=x(K),$=K.match(/^([A-Za-z]:)[\\/]?/)?.[1],Y=k(K);if($){let X=B(Q,Y.slice(1));return`${$}${X}`}return B(Q,Y)}function zK(K){let Q=JK(K),Z=Q.lastIndexOf(".");if(Z<=0)return"";return Q.slice(Z)}function JK(K){let Q=K.split(/[\\/]/);return Q[Q.length-1]??""}function l(K,Q){if(HK(K))throw Error(`Absolute paths not allowed: ${K}`);let Z=DK(Q,K),$=WK(Q),Y=x($);if(Z!==$&&!Z.startsWith($+Y))throw Error(`Path escapes base directory: ${K}`);return Z}async function E(K,Q={}){let Z=Q.basePath??Q.io?.cwd()??globalThis.process?.cwd?.()??".",$=l(K,Z),Y=d(K),X=p(Y),H;if(Q.io){if(!await Q.io.exists($))throw Error(`File not found: ${K}`);H=X?await Q.io.readBinary($):await Q.io.readText($)}else if(typeof globalThis.Bun<"u"){let G=globalThis.Bun.file($);if(!await G.exists())throw Error(`File not found: ${K}`);H=X?await G.arrayBuffer():await G.text()}else throw Error("No IO adapter provided. Provide `options.io` (Node/Bun/Tauri) to load file bodies.");return{content:H,isBinary:X,mimeType:Y}}function g(K){return K.some((Q)=>Q.isFile)}async function y(K,Q={}){let Z=new FormData,$=Q.basePath??Q.io?.cwd()??globalThis.process?.cwd?.()??".";for(let Y of K)if(Y.isFile&&Y.path){let X=await E(Y.path,Q.io?{basePath:$,io:Q.io}:{basePath:$}),H=Y.filename??Q.io?.path.basename(Y.path)??_K(Y.path),U=new Blob([X.content],{type:X.mimeType});Z.append(Y.name,U,H)}else Z.append(Y.name,Y.value);return Z}function _K(K){let Q=K.split(/[\\/]/);return Q[Q.length-1]??""}function P(K){let Q=new URLSearchParams;for(let Z of K){if(Z.isFile)continue;Q.append(Z.name,Z.value)}return Q}var n=/\{\{([^}]+)\}\}/g,r=/^\$(\w+)\(([^)]*)\)$/;function s(K){if(!K.trim())return[];return K.split(",").map((Q)=>Q.trim())}function i(K,Q){let Z=Q.split("."),$=K;for(let Y of Z){if($===null||$===void 0)return;if(typeof $!=="object")return;$=$[Y]}return $}function wK(K,Q,Z={}){let{resolvers:$={},undefinedBehavior:Y="throw"}=Z;return K.replace(n,(X,H)=>{let U=H.trim(),G=U.match(r);if(G){let[,W,D]=G,j=$[`$${W}`];if(j){let J=s(D??""),A=j(...J);if(A instanceof Promise)throw Error(`Resolver $${W} returned a Promise. Use createInterpolator() for async resolvers.`);return String(A)}if(Y==="throw")throw Error(`Unknown resolver: $${W}`);return Y==="keep"?X:""}let z=i(Q,U);if(z===void 0){if(Y==="throw")throw Error(`Undefined variable: ${U}`);return Y==="keep"?X:""}return String(z)})}async function CK(K,Q,Z={}){let{resolvers:$={},undefinedBehavior:Y="throw"}=Z,X=[],H=new RegExp(n.source,"g"),U=H.exec(K);while(U!==null){let D=U[1];if(D===void 0){U=H.exec(K);continue}X.push({match:U[0],expression:D,index:U.index}),U=H.exec(K)}if(X.length===0)return K;let G=await Promise.all(X.map(async({match:D,expression:j})=>{let J=j.trim(),A=J.match(r);if(A){let[,C,_]=A,O=$[`$${C}`];if(O){let R=s(_??""),N=await O(...R);return String(N)}if(Y==="throw")throw Error(`Unknown resolver: $${C}`);return Y==="keep"?D:""}let V=i(Q,J);if(V===void 0){if(Y==="throw")throw Error(`Undefined variable: ${J}`);return Y==="keep"?D:""}return String(V)})),z="",W=0;for(let D=0;D<X.length;D++){let j=X[D];if(!j)continue;let{match:J,index:A}=j;z+=K.slice(W,A),z+=G[D],W=A+J.length}return z+=K.slice(W),z}function v(K,Q,Z){if(typeof K==="string")return wK(K,Q,Z);if(Array.isArray(K))return K.map(($)=>v($,Q,Z));if(K!==null&&typeof K==="object"){let $={};for(let[Y,X]of Object.entries(K))$[Y]=v(X,Q,Z);return $}return K}async function b(K,Q,Z){if(typeof K==="string")return await CK(K,Q,Z);if(Array.isArray(K))return await Promise.all(K.map(($)=>b($,Q,Z)));if(K!==null&&typeof K==="object"){let $={},Y=Object.entries(K),X=await Promise.all(Y.map(async([H,U])=>[H,await b(U,Q,Z)]));for(let[H,U]of X)$[H]=U;return $}return K}function VK(K,Q,Z={}){return v(K,Q,Z)}function f(K={}){return{async interpolate(Q,Z){return b(Q,Z,K)}}}var a=/^([^=]+?)\s*=\s*(.*)$/;function AK(K,Q){if(Q&&!Q.includes("form-data")&&!Q.includes("x-www-form-urlencoded"))return!1;let Z=K.split(/\r?\n/).filter(($)=>$.trim());if(Z.length===0)return!1;if(Z.length===1&&Z[0]?.includes("&"))return!1;return Z.every(($)=>a.test($))}function OK(K){let Q=[],Z=K.split(/\r?\n/).filter(($)=>$.trim());for(let $ of Z){let Y=$.match(a);if(!Y)continue;let X=Y[1],H=Y[2];if(!X)continue;let U=X.trim(),G=(H??"").trim();if(G.startsWith("@./")||G.startsWith("@{{")){G=G.slice(1);let W=G,D,j=G.indexOf(" | ");if(j!==-1)W=G.slice(0,j).trim(),D=G.slice(j+3).trim();Q.push(w({name:U,value:"",isFile:!0,path:W}).ifDefined("filename",D).build())}else Q.push({name:U,value:G,isFile:!1})}return Q}function L(K){let Q=[],Z=K.split(/\r?\n/),$=[],Y={lines:[]};for(let X of Z){let H=X.match(/^###\s*(.*)$/);if(H){if(Y.lines.length>0||$.length===0)$.push(Y);let U=H[1]?.trim();Y=w({lines:[]}).ifDefined("name",U||void 0).build()}else Y.lines.push(X)}$.push(Y);for(let X of $){if(X.lines.length===0&&!X.name)continue;let H=X.lines.join(`
2
- `),U=IK(H,X.name);if(U)Q.push(U)}return Q}function IK(K,Q){let Z=K.split(/\r?\n/),$={},Y=Q,X="",H="",U={},G,z,W,D=!1,j=[],J=!1;for(let V=0;V<Z.length;V++){let C=Z[V];if(C===void 0)continue;let _=C.trim();if(!J&&_==="")continue;if(!J&&(_.startsWith("#")||_.startsWith("//"))){let R=_.replace(/^(#|\/\/)\s*/,"").match(/^@(\w+)\s*(.*)?$/);if(R){let[,N,S]=R;if(N==="name")Y=S?.trim()||Y;else if(N)$[N]=S?.trim()||""}continue}if(!J){let O=_.match(/^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\s+(\S+)(\s+HTTP\/[\d.]+)?$/i);if(O){let N=O[1],S=O[2];if(!N||!S)continue;X=N.toUpperCase(),H=S,J=!0;continue}let R=_.match(/^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\s+(.+)$/i);if(R){let N=R[1],S=R[2];if(!N||!S)continue;X=N.toUpperCase(),H=S.trim(),J=!0;continue}continue}if(D)j.push(C);else if(_==="")D=!0;else{let O=C.match(/^([^:]+):\s*(.*)$/);if(O){let R=O[1];if(!R)continue;let N=O[2]??"";U[R.trim()]=N.trim()}}}if(!X||!H)return null;if(j.length>0){while(j.length>0&&j[j.length-1]?.trim()==="")j.pop();if(j.length===1){let V=j[0]?.trim().match(/^<\s+(.+)$/);if(V){let C=V[1];if(C)z={path:C}}else if(j[0]?.trim())G=j[0]}else if(j.length>0)G=j.join(`
3
- `)}let A=U["Content-Type"]||U["content-type"];if(G&&AK(G,A))W=OK(G),G=void 0;return w({method:X,url:H,headers:U,raw:K,meta:$}).ifDefined("name",Y).ifDefined("body",G).ifDefined("bodyFile",z).ifDefined("formData",W).build()}async function NK(K){return await q(K)}async function q(K,Q){if(Q){let Z=await Q.readText(K);return L(Z)}if(typeof globalThis.Bun<"u"){let Y=await globalThis.Bun.file(K).text();return L(Y)}throw Error("No IO adapter provided. Use parseFileWithIO(path, io) in this runtime.")}function I(K,Q){K?.(Q)}function o(K,Q){let Z=K[0];if(!Z)throw Error(Q);return Z}function FK(K){let Q=Math.max(K.lastIndexOf("/"),K.lastIndexOf("\\"));if(Q===-1)return".";return Q===0?K.slice(0,1):K.slice(0,Q)}function RK(K){if(K.startsWith("/")||K.startsWith("\\"))return!0;if(/^[A-Za-z]:[\\/]/.test(K))return!0;if(K.startsWith("\\\\"))return!0;return!1}function SK(K,Q){if(!K)return Q;if(!Q)return K;let Z=K.includes("\\")?"\\":"/",$=K.endsWith("/")||K.endsWith("\\")?K.slice(0,-1):K,Y=Q.startsWith("/")||Q.startsWith("\\")?Q.slice(1):Q;return`${$}${Z}${Y}`}function LK(K,Q){if(Q)return Q.path.dirname(Q.path.resolve(K));let Z=globalThis.process?.cwd?.()??".",$=RK(K)?K:SK(Z,K);return FK($)}function MK(K,Q){if(!Q)return K;let Z=K.Cookie||K.cookie||"";return{...K,Cookie:Z?`${Z}; ${Q}`:Q}}function m(K={}){let Q=K.transport??M(),Z=K.io,$=K.cookieStore,Y=K.onEvent,X=K.headerDefaults,H=f({resolvers:K.resolvers??{}});async function U(W,D){I(Y,{type:"parseStarted",source:"string"});let j=L(W);I(Y,{type:"parseFinished",source:"string",requestCount:j.length});let J=o(j,"No valid requests found in provided content.");I(Y,{type:"interpolateStarted"});let A={...D.variables??{}},V=await H.interpolate(J,A);I(Y,{type:"interpolateFinished"}),I(Y,{type:"compileStarted"});let C=D.basePath??Z?.cwd()??globalThis.process?.cwd?.()??".",{executeRequest:_}=await t(V,w({basePath:C}).ifDefined("io",Z).ifDefined("headerDefaults",X).build());return I(Y,{type:"compileFinished"}),{executeRequest:_,baseUrl:V.url}}async function G(W,D){I(Y,{type:"parseStarted",source:"file"});let j=await q(W,Z);I(Y,{type:"parseFinished",source:"file",requestCount:j.length});let J=o(j,`No valid requests found in file: ${W}`);I(Y,{type:"interpolateStarted"});let A={...D.variables??{}},V=await H.interpolate(J,A);I(Y,{type:"interpolateFinished"}),I(Y,{type:"compileStarted"});let C=LK(W,Z),{executeRequest:_}=await t(V,w({basePath:C}).ifDefined("io",Z).ifDefined("headerDefaults",X).build());return I(Y,{type:"compileFinished"}),{executeRequest:_,baseUrl:V.url}}async function z(W,D,j){let J=W.headers??{},A=$?await $.getCookieHeader(D):void 0,V=$?MK(J,A):J,C={...W,headers:V};I(Y,{type:"fetchStarted",method:C.method,url:D});try{let _=w({}).ifDefined("timeout",j.timeoutMs).ifDefined("signal",j.signal).ifDefined("followRedirects",j.followRedirects).ifDefined("validateSSL",j.validateSSL).ifDefined("proxy",j.proxy).build(),O=await u(C,_,Q);if(I(Y,{type:"fetchFinished",method:C.method,url:D,status:O.status}),$)await $.setFromResponse(D,O);return O}catch(_){throw I(Y,{type:"error",stage:"fetch",message:_ instanceof Error?_.message:String(_)}),_}}return{parseString:L,async runString(W,D={}){let{executeRequest:j,baseUrl:J}=await U(W,D);return await z(j,J,D)},async runFile(W,D={}){let{executeRequest:j,baseUrl:J}=await G(W,D);return await z(j,J,D)}}}async function t(K,Q){let Z={...Q.headerDefaults??{},...K.headers??{}},$=K.body;if(K.bodyFile){let X=await E(K.bodyFile.path,w({basePath:Q.basePath}).ifDefined("io",Q.io).build());if($=X.content,!Z["Content-Type"]&&!Z["content-type"])Z["Content-Type"]=X.mimeType}else if(K.formData&&K.formData.length>0){if(g(K.formData))$=await y(K.formData,w({basePath:Q.basePath}).ifDefined("io",Q.io).build()),delete Z["Content-Type"],delete Z["content-type"];else if($=P(K.formData),!Z["Content-Type"]&&!Z["content-type"])Z["Content-Type"]="application/x-www-form-urlencoded"}return{executeRequest:{method:K.method,url:K.url,headers:Z,...$!==void 0?{body:$}:{}}}}function BK(K={}){let Q={...K.variables},Z=K.cookieJar,$=K.timeout??30000,Y=K.defaults||{},X=Z?EK(Z):void 0,H=m(w({}).ifDefined("io",K.io).ifDefined("transport",K.transport).ifDefined("cookieStore",X).ifDefined("resolvers",K.resolvers).ifDefined("onEvent",K.onEvent).ifDefined("headerDefaults",Y.headers).build());function U(G){return{...Q,...G}}return{async run(G,z={}){return await H.runFile(G,w({variables:U(z.variables),timeoutMs:z.timeout??$}).ifDefined("signal",z.signal).ifDefined("followRedirects",Y.followRedirects).ifDefined("validateSSL",Y.validateSSL).ifDefined("proxy",Y.proxy).build())},async runString(G,z={}){return await H.runString(G,w({variables:U(z.variables),timeoutMs:z.timeout??$}).ifDefined("signal",z.signal).ifDefined("followRedirects",Y.followRedirects).ifDefined("validateSSL",Y.validateSSL).ifDefined("proxy",Y.proxy).ifDefined("basePath",z.basePath).build())},setVariables(G){Q={...Q,...G}},setVariable(G,z){Q[G]=z},getVariables(){return{...Q}}}}function EK(K){return{getCookieHeader(Q){try{return K.getCookieStringSync(Q)||void 0}catch{return}},setFromResponse(Q,Z){let $=TK(Z);for(let Y of $)K.setCookieSync(Y,Q,{ignoreError:!0})}}}function TK(K){let Z=K.headers.getSetCookie?.();if(Array.isArray(Z)&&Z.length>0)return Z;let $=K.headers.get("set-cookie");return $?[$]:[]}export{l as validateFilePath,q as parseFileWithIO,NK as parseFile,L as parse,E as loadFileBody,p as isBinaryMimeType,VK as interpolate,d as inferMimeType,g as hasFileFields,f as createInterpolator,T as createFetchTransport,m as createEngine,BK as createClient,M as createAutoTransport,P as buildUrlEncoded,y as buildFormData};
1
+ import{createRequire as ZD}from"node:module";var rD=ZD(import.meta.url);function s(D){throw Error(`${D} is not supported by this transport. Provide a transport that supports it.`)}function m(D=fetch){return{capabilities:{proxy:!1,validateSSL:!1},async fetch(g,E,F){if(F.proxy)s("proxy");if(F.validateSSL===!1)s("validateSSL=false");return await D(g,E)}}}function KD(){return typeof globalThis.Bun<"u"}function B(){if(!KD())return m(fetch);return{capabilities:{proxy:!0,validateSSL:!0},async fetch(D,g,E){let F={...g??{}};if(E.proxy!==void 0)F.proxy=E.proxy;if(E.validateSSL===!1)F.tls={rejectUnauthorized:!1};return await fetch(D,F)}}}import{access as QD,readFile as a}from"node:fs/promises";import*as x from"node:path";async function YD(D){try{return await QD(D),!0}catch{return!1}}function HD(){return{cwd:()=>process.cwd(),path:{resolve:(...D)=>x.resolve(...D),dirname:(D)=>x.dirname(D),basename:(D)=>x.basename(D),extname:(D)=>x.extname(D),isAbsolute:(D)=>x.isAbsolute(D),sep:x.sep},exists:YD,readText:async(D)=>await a(D,"utf8"),readBinary:async(D)=>{let g=await a(D);return g.buffer.slice(g.byteOffset,g.byteOffset+g.byteLength)}}}function R(D){let g={...D},E={when(F,W){if(F)g={...g,...W};return E},ifDefined(F,W){if(W!==void 0)g={...g,[F]:W};return E},build(){return g}};return E}function XD(D,g){return g!==void 0&&!["GET","HEAD"].includes(D.toUpperCase())}function jD(D,g){let E=XD(D.method,D.body)&&D.body!==void 0;return R({method:D.method,redirect:g.followRedirects?"follow":"manual",signal:g.signal}).ifDefined("headers",D.headers).ifDefined("body",E?D.body:void 0).build()}function GD(D){if(D.provided)return{signal:D.provided,isInternalTimeout:!1,cleanup:()=>{}};let g=new AbortController,E=setTimeout(()=>g.abort(),D.timeout);return{signal:g.signal,isInternalTimeout:!0,cleanup:()=>clearTimeout(E)}}function UD(D,g){if(D instanceof Error&&D.name==="AbortError"){if(g.isInternalTimeout)return Error(`Request timeout after ${g.timeout}ms`)}return D instanceof Error?D:Error(String(D))}async function e(D,g,E){let F=g.timeout??30000,W=R({timeout:F}).ifDefined("provided",g.signal).build(),{signal:O,isInternalTimeout:$,cleanup:w}=GD(W),C=R({followRedirects:g.followRedirects??!0,signal:O}).build(),H=jD(D,C);try{let K=R({}).ifDefined("proxy",g.proxy).ifDefined("validateSSL",g.validateSSL).build();return await E.fetch(D.url,H,K)}catch(K){throw UD(K,{timeout:F,isInternalTimeout:$})}finally{w()}}var RD={".json":"application/json",".xml":"application/xml",".txt":"text/plain",".html":"text/html",".htm":"text/html",".css":"text/css",".js":"application/javascript",".mjs":"application/javascript",".ts":"application/typescript",".csv":"text/csv",".md":"text/markdown",".yaml":"text/yaml",".yml":"text/yaml",".svg":"image/svg+xml",".jpg":"image/jpeg",".jpeg":"image/jpeg",".png":"image/png",".gif":"image/gif",".webp":"image/webp",".ico":"image/x-icon",".bmp":"image/bmp",".tiff":"image/tiff",".tif":"image/tiff",".pdf":"application/pdf",".doc":"application/msword",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".xls":"application/vnd.ms-excel",".xlsx":"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",".ppt":"application/vnd.ms-powerpoint",".pptx":"application/vnd.openxmlformats-officedocument.presentationml.presentation",".zip":"application/zip",".gz":"application/gzip",".tar":"application/x-tar",".rar":"application/vnd.rar",".7z":"application/x-7z-compressed",".mp3":"audio/mpeg",".wav":"audio/wav",".ogg":"audio/ogg",".m4a":"audio/mp4",".mp4":"video/mp4",".webm":"video/webm",".avi":"video/x-msvideo",".mov":"video/quicktime",".wasm":"application/wasm",".bin":"application/octet-stream",".exe":"application/octet-stream",".dll":"application/octet-stream",".so":"application/octet-stream",".dylib":"application/octet-stream"},_D=new Set(["application/json","application/xml","application/javascript","application/typescript","text/plain","text/html","text/css","text/csv","text/xml","text/markdown","text/yaml","image/svg+xml"]);function DD(D){let g=AD(D).toLowerCase();return RD[g]??"application/octet-stream"}function gD(D){if(D.startsWith("text/"))return!1;if(_D.has(D))return!1;return!0}function h(D){return D.includes("\\")?"\\":"/"}function c(D){return D.split(/[\\/]+/).filter(Boolean)}function JD(D){if(D.startsWith("/")||D.startsWith("\\"))return!0;if(/^[A-Za-z]:[\\/]/.test(D))return!0;if(D.startsWith("\\\\"))return!0;return!1}function y(D,g){let E=[];for(let F of g){if(!F||F===".")continue;if(F===".."){E.pop();continue}E.push(F)}return(D==="\\"?"\\":"/")+E.join(D)}function qD(D,g){let E=h(D),F=/^[A-Za-z]:$/.test(D),O=D.match(/^([A-Za-z]:)[\\/]?/)?.[1],$=c(D),w=c(g);if(O){let C=y(E,[...$.slice(1),...w]);return`${O}${C}`}if(F){let C=y(E,w);return`${D}${C}`}return y(E,[...$,...w])}function zD(D){if(D==="")return"/";let g=h(D),F=D.match(/^([A-Za-z]:)[\\/]?/)?.[1],W=c(D);if(F){let O=y(g,W.slice(1));return`${F}${O}`}return y(g,W)}function AD(D){let g=ND(D),E=g.lastIndexOf(".");if(E<=0)return"";return g.slice(E)}function ND(D){let g=D.split(/[\\/]/);return g[g.length-1]??""}function ED(D,g){if(JD(D))throw Error(`Absolute paths not allowed: ${D}`);let E=qD(g,D),F=zD(g),W=h(F);if(E!==F&&!E.startsWith(F+W))throw Error(`Path escapes base directory: ${D}`);return E}async function P(D,g={}){let E=g.basePath??g.io?.cwd()??globalThis.process?.cwd?.()??".",F=ED(D,E),W=DD(D),O=gD(W),$;if(g.io){if(!await g.io.exists(F))throw Error(`File not found: ${D}`);$=O?await g.io.readBinary(F):await g.io.readText(F)}else if(typeof globalThis.Bun<"u"){let C=globalThis.Bun.file(F);if(!await C.exists())throw Error(`File not found: ${D}`);$=O?await C.arrayBuffer():await C.text()}else throw Error("No IO adapter provided. Provide `options.io` (Node/Bun/Tauri) to load file bodies.");return{content:$,isBinary:O,mimeType:W}}function b(D){return D.some((g)=>g.isFile)}async function u(D,g={}){let E=new FormData,F=g.basePath??g.io?.cwd()??globalThis.process?.cwd?.()??".";for(let W of D)if(W.isFile&&W.path){let O=await P(W.path,g.io?{basePath:F,io:g.io}:{basePath:F}),$=W.filename??g.io?.path.basename(W.path)??SD(W.path),w=new Blob([O.content],{type:O.mimeType});E.append(W.name,w,$)}else E.append(W.name,W.value);return E}function SD(D){let g=D.split(/[\\/]/);return g[g.length-1]??""}function v(D){let g=new URLSearchParams;for(let E of D){if(E.isFile)continue;g.append(E.name,E.value)}return g}function xD(D){return/^[A-Za-z0-9_]+$/.test(D)}function p(D){let g=[],E=0,F=0;while(E<D.length){let W=D[E],O=D[E+1];if(W==="{"&&O==="{"){if(E>F)g.push({type:"text",value:D.slice(F,E)});let $=E;E+=2;let w=1,C="";while(E<D.length){let K=D[E],Z=D[E+1];if(K==="{"&&Z==="{"){w++,C+="{{",E+=2;continue}if(K==="}"&&Z==="}"){if(w--,w===0){E+=2;break}C+="}}",E+=2;continue}C+=K,E++}if(w!==0)throw Error('Unterminated interpolation: missing "}}"');let H=D.slice($,E);g.push({type:"expr",expression:C,raw:H}),F=E;continue}E++}if(F<D.length)g.push({type:"text",value:D.slice(F)});return g}function r(D,g){let E=g.split("."),F=D;for(let W of E){if(F===null||F===void 0)return;if(typeof F!=="object")return;F=F[W]}return F}function t(D){let g=D.trim();if(!g.startsWith("$"))return null;if(!g.endsWith(")"))return null;let E=g.indexOf("(");if(E===-1)return null;let F=g.slice(1,E).trim();if(!F||!xD(F))return null;let W=g.slice(E+1,-1);return{resolverKey:`$${F}`,argText:W}}function TD(D,g,E){let F=p(D);if(F.length===1&&F[0]?.type==="text")return D;let W="";for(let O of F){if(O.type==="text"){W+=O.value;continue}let $=O.expression.trim();if(t($))throw Error(`Resolver calls are not allowed inside resolver args: ${O.raw}`);let w=r(g,$);if(w===void 0){if(E==="throw")throw Error(`Undefined variable: ${$}`);W+=E==="keep"?O.raw:"";continue}W+=String(w)}return W}function FD(D,g,E){let F=TD(D,g,E).trim();if(!F)return[];try{let W=JSON.parse(F);if(Array.isArray(W))return W.map((O)=>String(O))}catch{}return[F]}function VD(D,g,E={}){let{resolvers:F={},undefinedBehavior:W="throw"}=E,O=p(D);if(O.length===1&&O[0]?.type==="text")return D;let $="";for(let w of O){if(w.type==="text"){$+=w.value;continue}let C=t(w.expression);if(C){let Z=F[C.resolverKey];if(Z){let Q=FD(C.argText,g,W),X=Z(...Q);if(X instanceof Promise)throw Error(`Resolver ${C.resolverKey} returned a Promise. Use createInterpolator() for async resolvers.`);$+=String(X);continue}if(W==="throw")throw Error(`Unknown resolver: ${C.resolverKey}`);$+=W==="keep"?w.raw:"";continue}let H=w.expression.trim(),K=r(g,H);if(K===void 0){if(W==="throw")throw Error(`Undefined variable: ${H}`);$+=W==="keep"?w.raw:"";continue}$+=String(K)}return $}async function ID(D,g,E={}){let{resolvers:F={},undefinedBehavior:W="throw"}=E,O=p(D);if(O.length===1&&O[0]?.type==="text")return D;let $="";for(let w of O){if(w.type==="text"){$+=w.value;continue}let C=t(w.expression);if(C){let Z=F[C.resolverKey];if(Z){let Q=FD(C.argText,g,W),X=await Z(...Q);$+=String(X);continue}if(W==="throw")throw Error(`Unknown resolver: ${C.resolverKey}`);$+=W==="keep"?w.raw:"";continue}let H=w.expression.trim(),K=r(g,H);if(K===void 0){if(W==="throw")throw Error(`Undefined variable: ${H}`);$+=W==="keep"?w.raw:"";continue}$+=String(K)}return $}function d(D,g,E){if(typeof D==="string")return VD(D,g,E);if(Array.isArray(D))return D.map((F)=>d(F,g,E));if(D!==null&&typeof D==="object"){let F={};for(let[W,O]of Object.entries(D))F[W]=d(O,g,E);return F}return D}async function n(D,g,E){if(typeof D==="string")return await ID(D,g,E);if(Array.isArray(D))return await Promise.all(D.map((F)=>n(F,g,E)));if(D!==null&&typeof D==="object"){let F={},W=Object.entries(D),O=await Promise.all(W.map(async([$,w])=>[$,await n(w,g,E)]));for(let[$,w]of O)F[$]=w;return F}return D}function LD(D,g,E={}){return d(D,g,E)}function l(D={}){return{async interpolate(g,E){return n(g,E,D)}}}var WD=/^([^=]+?)\s*=\s*(.*)$/;function MD(D,g){if(g&&!g.includes("form-data")&&!g.includes("x-www-form-urlencoded"))return!1;let E=D.split(/\r?\n/).filter((F)=>F.trim());if(E.length===0)return!1;if(E.length===1&&E[0]?.includes("&"))return!1;return E.every((F)=>WD.test(F))}function kD(D){let g=[],E=D.split(/\r?\n/).filter((F)=>F.trim());for(let F of E){let W=F.match(WD);if(!W)continue;let O=W[1],$=W[2];if(!O)continue;let w=O.trim(),C=($??"").trim();if(C.startsWith("@./")||C.startsWith("@{{")){C=C.slice(1);let K=C,Z,Q=C.indexOf(" | ");if(Q!==-1)K=C.slice(0,Q).trim(),Z=C.slice(Q+3).trim();g.push(R({name:w,value:"",isFile:!0,path:K}).ifDefined("filename",Z).build())}else g.push({name:w,value:C,isFile:!1})}return g}function M(D){let g=[],E=D.split(/\r?\n/),F=[],W={lines:[]};for(let O of E){let $=O.match(/^###\s*(.*)$/);if($){if(W.lines.length>0||F.length===0)F.push(W);let w=$[1]?.trim();W=R({lines:[]}).ifDefined("name",w||void 0).build()}else W.lines.push(O)}F.push(W);for(let O of F){if(O.lines.length===0&&!O.name)continue;let $=O.lines.join(`
2
+ `),w=BD($,O.name);if(w)g.push(w)}return g}function BD(D,g){let E=D.split(/\r?\n/),F={},W=g,O="",$="",w={},C,H,K,Z=!1,Q=[],X=!1;for(let J=0;J<E.length;J++){let G=E[J];if(G===void 0)continue;let U=G.trim();if(!X&&U==="")continue;if(!X&&(U.startsWith("#")||U.startsWith("//"))){let S=U.replace(/^(#|\/\/)\s*/,"").match(/^@(\w+)\s*(.*)?$/);if(S){let[,N,T]=S;if(N==="name")W=T?.trim()||W;else if(N)F[N]=T?.trim()||""}continue}if(!X){let q=U.match(/^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\s+(\S+)(\s+HTTP\/[\d.]+)?$/i);if(q){let N=q[1],T=q[2];if(!N||!T)continue;O=N.toUpperCase(),$=T,X=!0;continue}let S=U.match(/^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\s+(.+)$/i);if(S){let N=S[1],T=S[2];if(!N||!T)continue;O=N.toUpperCase(),$=T.trim(),X=!0;continue}continue}if(Z)Q.push(G);else if(U==="")Z=!0;else{let q=G.match(/^([^:]+):\s*(.*)$/);if(q){let S=q[1];if(!S)continue;let N=q[2]??"";w[S.trim()]=N.trim()}}}if(!O||!$)return null;if(Q.length>0){while(Q.length>0&&Q[Q.length-1]?.trim()==="")Q.pop();if(Q.length===1){let J=Q[0]?.trim().match(/^<\s+(.+)$/);if(J){let G=J[1];if(G)H={path:G}}else if(Q[0]?.trim())C=Q[0]}else if(Q.length>0)C=Q.join(`
3
+ `)}let A=w["Content-Type"]||w["content-type"];if(C&&MD(C,A))K=kD(C),C=void 0;return R({method:O,url:$,headers:w,raw:D,meta:F}).ifDefined("name",W).ifDefined("body",C).ifDefined("bodyFile",H).ifDefined("formData",K).build()}async function yD(D){return await f(D)}async function f(D,g){if(g){let E=await g.readText(D);return M(E)}if(typeof globalThis.Bun<"u"){let W=await globalThis.Bun.file(D).text();return M(W)}throw Error("No IO adapter provided. Use parseFileWithIO(path, io) in this runtime.")}function z(D,g){D?.(g)}function OD(D,g){let E=D[0];if(!E)throw Error(g);return E}function PD(D){let g=Math.max(D.lastIndexOf("/"),D.lastIndexOf("\\"));if(g===-1)return".";return g===0?D.slice(0,1):D.slice(0,g)}function mD(D){if(D.startsWith("/")||D.startsWith("\\"))return!0;if(/^[A-Za-z]:[\\/]/.test(D))return!0;if(D.startsWith("\\\\"))return!0;return!1}function fD(D,g){if(!D)return g;if(!g)return D;let E=D.includes("\\")?"\\":"/",F=D.endsWith("/")||D.endsWith("\\")?D.slice(0,-1):D,W=g.startsWith("/")||g.startsWith("\\")?g.slice(1):g;return`${F}${E}${W}`}function cD(D,g){if(g)return g.path.dirname(g.path.resolve(D));let E=globalThis.process?.cwd?.()??".",F=mD(D)?D:fD(E,D);return PD(F)}function hD(D,g){if(!g)return D;let E=D.Cookie||D.cookie||"";return{...D,Cookie:E?`${E}; ${g}`:g}}function i(D={}){let g=D.transport??B(),E=D.io,F=D.cookieStore,W=D.onEvent,O=D.headerDefaults,$=l({resolvers:D.resolvers??{}});async function w(K,Z){z(W,{type:"parseStarted",source:"string"});let Q=M(K);z(W,{type:"parseFinished",source:"string",requestCount:Q.length});let X=OD(Q,"No valid requests found in provided content.");z(W,{type:"interpolateStarted"});let A={...Z.variables??{}},J=await $.interpolate(X,A);z(W,{type:"interpolateFinished"}),z(W,{type:"compileStarted"});let G=Z.basePath??E?.cwd()??globalThis.process?.cwd?.()??".",{executeRequest:U}=await wD(J,R({basePath:G}).ifDefined("io",E).ifDefined("headerDefaults",O).build());return z(W,{type:"compileFinished"}),{executeRequest:U,baseUrl:J.url}}async function C(K,Z){z(W,{type:"parseStarted",source:"file"});let Q=await f(K,E);z(W,{type:"parseFinished",source:"file",requestCount:Q.length});let X=OD(Q,`No valid requests found in file: ${K}`);z(W,{type:"interpolateStarted"});let A={...Z.variables??{}},J=await $.interpolate(X,A);z(W,{type:"interpolateFinished"}),z(W,{type:"compileStarted"});let G=cD(K,E),{executeRequest:U}=await wD(J,R({basePath:G}).ifDefined("io",E).ifDefined("headerDefaults",O).build());return z(W,{type:"compileFinished"}),{executeRequest:U,baseUrl:J.url}}async function H(K,Z,Q){let X=K.headers??{},A=F?await F.getCookieHeader(Z):void 0,J=F?hD(X,A):X,G={...K,headers:J};z(W,{type:"fetchStarted",method:G.method,url:Z});try{let U=R({}).ifDefined("timeout",Q.timeoutMs).ifDefined("signal",Q.signal).ifDefined("followRedirects",Q.followRedirects).ifDefined("validateSSL",Q.validateSSL).ifDefined("proxy",Q.proxy).build(),q=await e(G,U,g);if(z(W,{type:"fetchFinished",method:G.method,url:Z,status:q.status}),F)await F.setFromResponse(Z,q);return q}catch(U){throw z(W,{type:"error",stage:"fetch",message:U instanceof Error?U.message:String(U)}),U}}return{parseString:M,async runString(K,Z={}){let{executeRequest:Q,baseUrl:X}=await w(K,Z);return await H(Q,X,Z)},async runFile(K,Z={}){let{executeRequest:Q,baseUrl:X}=await C(K,Z);return await H(Q,X,Z)}}}async function wD(D,g){let E={...g.headerDefaults??{},...D.headers??{}},F=D.body;if(D.bodyFile){let O=await P(D.bodyFile.path,R({basePath:g.basePath}).ifDefined("io",g.io).build());if(F=O.content,!E["Content-Type"]&&!E["content-type"])E["Content-Type"]=O.mimeType}else if(D.formData&&D.formData.length>0){if(b(D.formData))F=await u(D.formData,R({basePath:g.basePath}).ifDefined("io",g.io).build()),delete E["Content-Type"],delete E["content-type"];else if(F=v(D.formData),!E["Content-Type"]&&!E["content-type"])E["Content-Type"]="application/x-www-form-urlencoded"}return{executeRequest:{method:D.method,url:D.url,headers:E,...F!==void 0?{body:F}:{}}}}var o=Symbol("serverMetadata");function k(D){if(typeof process<"u"&&process.env)return process.env[D];return}function $D(D){let{serverUrl:g}=D,E=k("TREQ_FLOW_ID"),F=k("TREQ_SESSION_ID"),O=k("TREQ_TOKEN")??D.token,$=g.replace(/\/$/,""),w={...D.variables},C=F,H=E,K=!1,Z,Q=!!E,X=!!F,A=Promise.resolve(),J=D.timeout??30000,G={"Content-Type":"application/json"};if(O)G.Authorization=`Bearer ${O}`;async function U(){if(K)return;if(Z)return Z;return Z=(async()=>{if(X){K=!0;return}let Y=await fetch(`${$}/session`,{method:"POST",headers:G,body:JSON.stringify({variables:w})});if(!Y.ok){let _=await Y.text();throw Error(`Failed to create session: ${_}`)}if(C=(await Y.json()).sessionId,!Q){let _=await fetch(`${$}/flows`,{method:"POST",headers:G,body:JSON.stringify({sessionId:C})});if(!_.ok){let I=await _.text();throw Error(`Failed to create flow: ${I}`)}H=(await _.json()).flowId}K=!0})(),Z}function q(Y){let j=async()=>{if(!C)return;try{let _=await fetch(`${$}/session/${C}/variables`,{method:"PUT",headers:G,body:JSON.stringify({variables:Y,mode:"merge"})});if(!_.ok)console.error("Failed to sync variables to server:",_.statusText)}catch(_){console.error("Failed to sync variables to server:",_)}};if(C)A=A.catch(()=>{return}).then(j);else if(Z)A=A.catch(()=>{return}).then(()=>Z).then(j)}async function S(Y,j={}){await U(),await A;let _={...Y,sessionId:C,flowId:H,profile:D.profile,timeoutMs:j.timeout??J};if(Y.path)_.reqLabel=Y.path;if(j.variables&&Object.keys(j.variables).length>0)_.variables=j.variables;if(j.basePath)_.basePath=j.basePath;let V={method:"POST",headers:G,body:JSON.stringify(_)};if(j.signal)V.signal=j.signal;let I=await fetch(`${$}/execute`,V);if(!I.ok){let CD=await I.text();throw Error(`Execution failed: ${CD}`)}let L=await I.json();return N(L.response)}function N(Y){let j;if(Y.body!==void 0)if(Y.encoding==="base64"){let V=atob(Y.body),I=new Uint8Array(V.length);for(let L=0;L<V.length;L++)I[L]=V.charCodeAt(L);j=I}else j=Y.body;let _=new Headers;for(let V of Y.headers)_.append(V.name,V.value);return new Response(j,{status:Y.status,statusText:Y.statusText,headers:_})}async function T(){if(!H||Q)return;try{await fetch(`${$}/flows/${H}/finish`,{method:"POST",headers:G})}catch{}}return{async run(Y,j={}){return S({path:Y},j)},async runString(Y,j={}){return S({content:Y},j)},setVariables(Y){w={...w,...Y},q(Y)},setVariable(Y,j){w[Y]=j,q({[Y]:j})},getVariables(){return{...w}},close:T,[Symbol.asyncDispose]:T,[o]:()=>({serverUrl:$,sessionId:C,flowId:H})}}function bD(D={}){let g=D.server??k("TREQ_SERVER");if(g)return $D({...D,serverUrl:g,token:D.serverToken??k("TREQ_TOKEN")});let E={...D.variables},F=D.cookieJar,W=D.timeout??30000,O=D.defaults||{},$=F?uD(F):void 0,w=i(R({}).ifDefined("io",D.io).ifDefined("transport",D.transport).ifDefined("cookieStore",$).ifDefined("resolvers",D.resolvers).ifDefined("onEvent",D.onEvent).ifDefined("headerDefaults",O.headers).build());function C(K){return{...E,...K}}async function H(){}return{async run(K,Z={}){return await w.runFile(K,R({variables:C(Z.variables),timeoutMs:Z.timeout??W}).ifDefined("signal",Z.signal).ifDefined("followRedirects",O.followRedirects).ifDefined("validateSSL",O.validateSSL).ifDefined("proxy",O.proxy).build())},async runString(K,Z={}){return await w.runString(K,R({variables:C(Z.variables),timeoutMs:Z.timeout??W}).ifDefined("signal",Z.signal).ifDefined("followRedirects",O.followRedirects).ifDefined("validateSSL",O.validateSSL).ifDefined("proxy",O.proxy).ifDefined("basePath",Z.basePath).build())},setVariables(K){E={...E,...K}},setVariable(K,Z){E[K]=Z},getVariables(){return{...E}},close:H,[Symbol.asyncDispose]:H}}function uD(D){return{getCookieHeader(g){try{return D.getCookieStringSync(g)||void 0}catch{return}},setFromResponse(g,E){let F=vD(E);for(let W of F)D.setCookieSync(W,g,{ignoreError:!0})}}}function vD(D){let E=D.headers.getSetCookie?.();if(Array.isArray(E)&&E.length>0)return E;let F=D.headers.get("set-cookie");return F?[F]:[]}function dD(D){let E=D[o];if(typeof E==="function")return E();return}export{ED as validateFilePath,f as parseFileWithIO,yD as parseFile,M as parse,P as loadFileBody,gD as isBinaryMimeType,LD as interpolate,DD as inferMimeType,b as hasFileFields,dD as getServerMetadata,l as createInterpolator,m as createFetchTransport,i as createEngine,bD as createClient,B as createAutoTransport,v as buildUrlEncoded,u as buildFormData};
4
4
 
5
- //# debugId=F03ED57A9C94A10164756E2164756E21
5
+ //# debugId=26111198FAA8274364756E2164756E21
6
6
  //# sourceMappingURL=index.js.map