@t-req/core 0.1.0 → 0.2.1

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 (68) hide show
  1. package/README.md +204 -14
  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 +50 -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 +9 -2
  9. package/dist/config/index.js.map +23 -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 +74 -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 +3 -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 +4 -0
  33. package/dist/index.d.ts.map +1 -1
  34. package/dist/index.js +8 -4
  35. package/dist/index.js.map +21 -7
  36. package/dist/interpolate.d.ts.map +1 -1
  37. package/dist/plugin/define.d.ts +65 -0
  38. package/dist/plugin/define.d.ts.map +1 -0
  39. package/dist/plugin/index.d.ts +7 -0
  40. package/dist/plugin/index.d.ts.map +1 -0
  41. package/dist/plugin/index.js +8 -0
  42. package/dist/plugin/index.js.map +22 -0
  43. package/dist/plugin/loader.d.ts +69 -0
  44. package/dist/plugin/loader.d.ts.map +1 -0
  45. package/dist/plugin/manager.d.ts +186 -0
  46. package/dist/plugin/manager.d.ts.map +1 -0
  47. package/dist/plugin/permissions.d.ts +33 -0
  48. package/dist/plugin/permissions.d.ts.map +1 -0
  49. package/dist/plugin/subprocess.d.ts +100 -0
  50. package/dist/plugin/subprocess.d.ts.map +1 -0
  51. package/dist/plugin/types.d.ts +668 -0
  52. package/dist/plugin/types.d.ts.map +1 -0
  53. package/dist/resolver/command.d.ts +19 -0
  54. package/dist/resolver/command.d.ts.map +1 -0
  55. package/dist/resolver/index.d.ts +2 -0
  56. package/dist/resolver/index.d.ts.map +1 -0
  57. package/dist/resolver/index.js +5 -0
  58. package/dist/resolver/index.js.map +10 -0
  59. package/dist/runtime/index.js +2 -2
  60. package/dist/runtime/index.js.map +2 -2
  61. package/dist/runtime/types.d.ts.map +1 -1
  62. package/dist/server-client.d.ts +50 -0
  63. package/dist/server-client.d.ts.map +1 -0
  64. package/dist/server-metadata.d.ts +13 -0
  65. package/dist/server-metadata.d.ts.map +1 -0
  66. package/dist/types.d.ts +41 -0
  67. package/dist/types.d.ts.map +1 -1
  68. package/package.json +20 -5
@@ -1,4 +1,5 @@
1
1
  import { parse } from '../parser';
2
+ import type { PluginManager } from '../plugin/manager';
2
3
  import type { CookieStore, EventSink, IO, Transport } from '../runtime/types';
3
4
  import type { Resolver } from '../types';
4
5
  export type EngineConfig = {
@@ -8,6 +9,8 @@ export type EngineConfig = {
8
9
  resolvers?: Record<string, Resolver>;
9
10
  onEvent?: EventSink;
10
11
  headerDefaults?: Record<string, string>;
12
+ pluginManager?: PluginManager;
13
+ maxRetries?: number;
11
14
  };
12
15
  export type EngineRunOptions = {
13
16
  variables?: Record<string, unknown>;
@@ -16,10 +19,6 @@ export type EngineRunOptions = {
16
19
  followRedirects?: boolean;
17
20
  validateSSL?: boolean;
18
21
  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
22
  basePath?: string;
24
23
  };
25
24
  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;AACnD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAUvD,OAAO,KAAK,EAAE,WAAW,EAAe,SAAS,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC3F,OAAO,KAAK,EAA4D,QAAQ,EAAE,MAAM,UAAU,CAAC;AAGnG,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;IACxC,aAAa,CAAC,EAAE,aAAa,CAAC;IAC9B,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,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;AAkEF,wBAAgB,YAAY,CAAC,MAAM,GAAE,YAAiB,GAAG,MAAM,CA4Y9D"}
@@ -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 _G}from"node:module";var jG=Object.defineProperty;var uG=(G,K)=>{for(var Q in K)jG(G,Q,{get:K[Q],enumerable:!0,configurable:!0,set:(Z)=>K[Q]=()=>Z})};var pG=_G(import.meta.url);function i(G){throw Error(`${G} is not supported by this transport. Provide a transport that supports it.`)}function o(G=fetch){return{capabilities:{proxy:!1,validateSSL:!1},async fetch(K,Q,Z){if(Z.proxy)i("proxy");if(Z.validateSSL===!1)i("validateSSL=false");return await G(K,Q)}}}function WG(){return typeof globalThis.Bun<"u"}function v(){if(!WG())return o(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 E(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 zG(G,K){return K!==void 0&&!["GET","HEAD"].includes(G.toUpperCase())}function VG(G,K){let Q=zG(G.method,G.body)&&G.body!==void 0;return E({method:G.method,redirect:K.followRedirects?"follow":"manual",signal:K.signal}).ifDefined("headers",G.headers).ifDefined("body",Q?G.body:void 0).build()}function AG(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 DG(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 s(G,K,Q){let Z=K.timeout??30000,$=E({timeout:Z}).ifDefined("provided",K.signal).build(),{signal:X,isInternalTimeout:Y,cleanup:H}=AG($),J=E({followRedirects:K.followRedirects??!0,signal:X}).build(),z=VG(G,J);try{let w=E({}).ifDefined("proxy",K.proxy).ifDefined("validateSSL",K.validateSSL).build();return await Q.fetch(G.url,z,w)}catch(w){throw DG(w,{timeout:Z,isInternalTimeout:Y})}finally{H()}}var NG={".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"},CG=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 K=FG(G).toLowerCase();return NG[K]??"application/octet-stream"}function SG(G){if(G.startsWith("text/"))return!1;if(CG.has(G))return!1;return!0}function m(G){return G.includes("\\")?"\\":"/"}function b(G){return G.split(/[\\/]+/).filter(Boolean)}function EG(G){if(G.startsWith("/")||G.startsWith("\\"))return!0;if(/^[A-Za-z]:[\\/]/.test(G))return!0;if(G.startsWith("\\\\"))return!0;return!1}function k(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 IG(G,K){let Q=m(G),Z=/^[A-Za-z]:$/.test(G),X=G.match(/^([A-Za-z]:)[\\/]?/)?.[1],Y=b(G),H=b(K);if(X){let J=k(Q,[...Y.slice(1),...H]);return`${X}${J}`}if(Z){let J=k(Q,H);return`${G}${J}`}return k(Q,[...Y,...H])}function LG(G){if(G==="")return"/";let K=m(G),Z=G.match(/^([A-Za-z]:)[\\/]?/)?.[1],$=b(G);if(Z){let X=k(K,$.slice(1));return`${Z}${X}`}return k(K,$)}function FG(G){let K=MG(G),Q=K.lastIndexOf(".");if(Q<=0)return"";return K.slice(Q)}function MG(G){let K=G.split(/[\\/]/);return K[K.length-1]??""}function RG(G,K){if(EG(G))throw Error(`Absolute paths not allowed: ${G}`);let Q=IG(K,G),Z=LG(K),$=m(Z);if(Q!==Z&&!Q.startsWith(Z+$))throw Error(`Path escapes base directory: ${G}`);return Q}async function x(G,K={}){let Q=K.basePath??K.io?.cwd()??globalThis.process?.cwd?.()??".",Z=RG(G,Q),$=wG(G),X=SG($),Y;if(K.io){if(!await K.io.exists(Z))throw Error(`File not found: ${G}`);Y=X?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}`);Y=X?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:Y,isBinary:X,mimeType:$}}function a(G){return G.some((K)=>K.isFile)}async function r(G,K={}){let Q=new FormData,Z=K.basePath??K.io?.cwd()??globalThis.process?.cwd?.()??".";for(let $ of G)if($.isFile&&$.path){let X=await x($.path,K.io?{basePath:Z,io:K.io}:{basePath:Z}),Y=$.filename??K.io?.path.basename($.path)??TG($.path),H=new Blob([X.content],{type:X.mimeType});Q.append($.name,H,Y)}else Q.append($.name,$.value);return Q}function TG(G){let K=G.split(/[\\/]/);return K[K.length-1]??""}function t(G){let K=new URLSearchParams;for(let Q of G){if(Q.isFile)continue;K.append(Q.name,Q.value)}return K}function BG(G){return/^[A-Za-z0-9_]+$/.test(G)}function d(G){let K=[],Q=0,Z=0;while(Q<G.length){let $=G[Q],X=G[Q+1];if($==="{"&&X==="{"){if(Q>Z)K.push({type:"text",value:G.slice(Z,Q)});let Y=Q;Q+=2;let H=1,J="";while(Q<G.length){let w=G[Q],S=G[Q+1];if(w==="{"&&S==="{"){H++,J+="{{",Q+=2;continue}if(w==="}"&&S==="}"){if(H--,H===0){Q+=2;break}J+="}}",Q+=2;continue}J+=w,Q++}if(H!==0)throw Error('Unterminated interpolation: missing "}}"');let z=G.slice(Y,Q);K.push({type:"expr",expression:J,raw:z}),Z=Q;continue}Q++}if(Z<G.length)K.push({type:"text",value:G.slice(Z)});return K}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 l(G){let K=G.trim();if(!K.startsWith("$"))return null;if(!K.endsWith(")"))return null;let Q=K.indexOf("(");if(Q===-1)return null;let Z=K.slice(1,Q).trim();if(!Z||!BG(Z))return null;let $=K.slice(Q+1,-1);return{resolverKey:`$${Z}`,argText:$}}function kG(G,K,Q){let Z=d(G);if(Z.length===1&&Z[0]?.type==="text")return G;let $="";for(let X of Z){if(X.type==="text"){$+=X.value;continue}let Y=X.expression.trim();if(l(Y))throw Error(`Resolver calls are not allowed inside resolver args: ${X.raw}`);let H=u(K,Y);if(H===void 0){if(Q==="throw")throw Error(`Undefined variable: ${Y}`);$+=Q==="keep"?X.raw:"";continue}$+=String(H)}return $}function e(G,K,Q){let Z=kG(G,K,Q).trim();if(!Z)return[];try{let $=JSON.parse(Z);if(Array.isArray($))return $.map((X)=>String(X))}catch{}return[Z]}function OG(G,K,Q={}){let{resolvers:Z={},undefinedBehavior:$="throw"}=Q,X=d(G);if(X.length===1&&X[0]?.type==="text")return G;let Y="";for(let H of X){if(H.type==="text"){Y+=H.value;continue}let J=l(H.expression);if(J){let S=Z[J.resolverKey];if(S){let N=e(J.argText,K,$),L=S(...N);if(L instanceof Promise)throw Error(`Resolver ${J.resolverKey} returned a Promise. Use createInterpolator() for async resolvers.`);Y+=String(L);continue}if($==="throw")throw Error(`Unknown resolver: ${J.resolverKey}`);Y+=$==="keep"?H.raw:"";continue}let z=H.expression.trim(),w=u(K,z);if(w===void 0){if($==="throw")throw Error(`Undefined variable: ${z}`);Y+=$==="keep"?H.raw:"";continue}Y+=String(w)}return Y}async function gG(G,K,Q={}){let{resolvers:Z={},undefinedBehavior:$="throw"}=Q,X=d(G);if(X.length===1&&X[0]?.type==="text")return G;let Y="";for(let H of X){if(H.type==="text"){Y+=H.value;continue}let J=l(H.expression);if(J){let S=Z[J.resolverKey];if(S){let N=e(J.argText,K,$),L=await S(...N);Y+=String(L);continue}if($==="throw")throw Error(`Unknown resolver: ${J.resolverKey}`);Y+=$==="keep"?H.raw:"";continue}let z=H.expression.trim(),w=u(K,z);if(w===void 0){if($==="throw")throw Error(`Undefined variable: ${z}`);Y+=$==="keep"?H.raw:"";continue}Y+=String(w)}return Y}function c(G,K,Q){if(typeof G==="string")return OG(G,K,Q);if(Array.isArray(G))return G.map((Z)=>c(Z,K,Q));if(G!==null&&typeof G==="object"){let Z={};for(let[$,X]of Object.entries(G))Z[$]=c(X,K,Q);return Z}return G}async function h(G,K,Q){if(typeof G==="string")return await gG(G,K,Q);if(Array.isArray(G))return await Promise.all(G.map((Z)=>h(Z,K,Q)));if(G!==null&&typeof G==="object"){let Z={},$=Object.entries(G),X=await Promise.all($.map(async([Y,H])=>[Y,await h(H,K,Q)]));for(let[Y,H]of X)Z[Y]=H;return Z}return G}function ZK(G,K,Q={}){return c(G,K,Q)}function GG(G={}){return{async interpolate(K,Q){return h(K,Q,G)}}}var KG=/^([^=]+?)\s*=\s*(.*)$/;function PG(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)=>KG.test(Z))}function yG(G){let K=[],Q=G.split(/\r?\n/).filter((Z)=>Z.trim());for(let Z of Q){let $=Z.match(KG);if(!$)continue;let X=$[1],Y=$[2];if(!X)continue;let H=X.trim(),J=(Y??"").trim();if(J.startsWith("@./")||J.startsWith("@{{")){J=J.slice(1);let w=J,S,N=J.indexOf(" | ");if(N!==-1)w=J.slice(0,N).trim(),S=J.slice(N+3).trim();K.push(E({name:H,value:"",isFile:!0,path:w}).ifDefined("filename",S).build())}else K.push({name:H,value:J,isFile:!1})}return K}function O(G){let K=[],Q=G.split(/\r?\n/),Z=[],$={lines:[]};for(let X of Q){let Y=X.match(/^###\s*(.*)$/);if(Y){if($.lines.length>0||Z.length===0)Z.push($);let H=Y[1]?.trim();$=E({lines:[]}).ifDefined("name",H||void 0).build()}else $.lines.push(X)}Z.push($);for(let X of Z){if(X.lines.length===0&&!X.name)continue;let Y=X.lines.join(`
2
+ `),H=xG(Y,X.name);if(H)K.push(H)}return K}function xG(G,K){let Q=G.split(/\r?\n/),Z={},$=K,X="",Y="",H={},J,z,w,S=!1,N=[],L=!1;for(let V=0;V<Q.length;V++){let C=Q[V];if(C===void 0)continue;let D=C.trim();if(!L&&D==="")continue;if(!L&&(D.startsWith("#")||D.startsWith("//"))){let W=D.replace(/^(#|\/\/)\s*/,"").match(/^@(\w+)\s*(.*)?$/);if(W){let[,A,F]=W;if(A==="name")$=F?.trim()||$;else if(A)Z[A]=F?.trim()||""}continue}if(!L){let _=D.match(/^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\s+(\S+)(\s+HTTP\/[\d.]+)?$/i);if(_){let A=_[1],F=_[2];if(!A||!F)continue;X=A.toUpperCase(),Y=F,L=!0;continue}let W=D.match(/^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\s+(.+)$/i);if(W){let A=W[1],F=W[2];if(!A||!F)continue;X=A.toUpperCase(),Y=F.trim(),L=!0;continue}continue}if(S)N.push(C);else if(D==="")S=!0;else{let _=C.match(/^([^:]+):\s*(.*)$/);if(_){let W=_[1];if(!W)continue;let A=_[2]??"";H[W.trim()]=A.trim()}}}if(!X||!Y)return null;if(N.length>0){while(N.length>0&&N[N.length-1]?.trim()==="")N.pop();if(N.length===1){let V=N[0]?.trim().match(/^<\s+(.+)$/);if(V){let C=V[1];if(C)z={path:C}}else if(N[0]?.trim())J=N[0]}else if(N.length>0)J=N.join(`
3
+ `)}let U=H["Content-Type"]||H["content-type"];if(J&&PG(J,U))w=yG(J),J=void 0;return E({method:X,url:Y,headers:H,raw:G,meta:Z}).ifDefined("name",$).ifDefined("body",J).ifDefined("bodyFile",z).ifDefined("formData",w).build()}async function XK(G){return await p(G)}async function p(G,K){if(K){let Q=await K.readText(G);return O(Q)}if(typeof globalThis.Bun<"u"){let $=await globalThis.Bun.file(G).text();return O($)}throw Error("No IO adapter provided. Use parseFileWithIO(path, io) in this runtime.")}function qG(G,K){G?.(K)}function QG(G,K){let Q=G[0];if(!Q)throw Error(K);return Q}function fG(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 vG(G){if(G.startsWith("/")||G.startsWith("\\"))return!0;if(/^[A-Za-z]:[\\/]/.test(G))return!0;if(G.startsWith("\\\\"))return!0;return!1}function bG(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 mG(G,K){if(K)return K.path.dirname(K.path.resolve(G));let Q=globalThis.process?.cwd?.()??".",Z=vG(G)?G:bG(Q,G);return fG(Z)}function cG(G,K){if(!K)return G;let Q=G.Cookie||G.cookie||"";return{...G,Cookie:Q?`${Q}; ${K}`:K}}function ZG(G){return new Promise((K)=>setTimeout(K,G))}function hG(G={}){let K=G.transport??v(),Q=G.io,Z=G.cookieStore,$=G.onEvent,X=G.headerDefaults,Y=G.pluginManager,H=G.maxRetries??3,J=GG({resolvers:G.resolvers??{}});function z(U){qG($,U),Y?.emitEngineEvent(U)}async function w(U,V){z({type:"parseStarted",source:"string"});let C=O(U);z({type:"parseFinished",source:"string",requestCount:C.length});let D=V.basePath??Q?.cwd()??globalThis.process?.cwd?.()??".";if(Y){let _={path:"string",requests:C},W={file:_};return await Y.triggerParseAfter({file:_,path:"string"},W),{requests:W.file.requests,basePath:D}}return{requests:C,basePath:D}}async function S(U,V){z({type:"parseStarted",source:"file"});let C=await p(U,Q);z({type:"parseFinished",source:"file",requestCount:C.length});let D=mG(U,Q);if(Y){let _={path:U,requests:C},W={file:_};return await Y.triggerParseAfter({file:_,path:U},W),{requests:W.file.requests,filePath:U,basePath:D}}return{requests:C,filePath:U,basePath:D}}async function N(U,V,C){let D=V.variables??{},_=0,W=()=>Y?.createHookContext({retries:_,maxRetries:H,variables:D})??{retries:_,maxRetries:H,session:{id:"default",variables:{}},variables:D,config:{projectRoot:".",variables:{},security:{allowExternalFiles:!1,allowPluginsOutsideProject:!1}},projectRoot:"."};while(!0)try{let A=await L(U,V,C,W(),_);if(A.retry&&_<H){_++,await ZG(A.retry.delayMs);continue}return A.response}catch(A){if(Y){let F={method:U.method,url:U.url,headers:U.headers,...U.body!==void 0?{body:U.body}:{}},R={error:A instanceof Error?A:Error(String(A)),suppress:!1};if(await Y.triggerError({request:F,error:A instanceof Error?A:Error(String(A)),ctx:W()},R),R.retry&&_<H){_++,await ZG(R.retry.delayMs);continue}if(R.suppress)return new Response(R.error.message,{status:0,statusText:"Suppressed Error"});throw R.error}throw A}}async function L(U,V,C,D,_){let W={method:U.method,url:U.url,headers:{...U.headers},...U.body!==void 0?{body:U.body}:{}};if(Y){let j={request:W,skip:!1};if((await Y.triggerRequestBefore({request:W,variables:V.variables??{},ctx:D},j)).skip)return{response:new Response(null,{status:204,statusText:"Skipped by Plugin"})};W=j.request}z({type:"interpolateStarted"});let A={...V.variables??{}},F={method:W.method,url:W.url,headers:W.headers,...W.body!==void 0?{body:W.body}:{},...U.name!==void 0?{name:U.name}:{},raw:U.raw,meta:U.meta,...U.bodyFile!==void 0?{bodyFile:U.bodyFile}:{},...U.formData!==void 0?{formData:U.formData}:{}},R=await J.interpolate(F,A);z({type:"interpolateFinished"}),z({type:"compileStarted"});let{executeRequest:B}=await dG(R,E({basePath:C}).ifDefined("io",Q).ifDefined("headerDefaults",X).build());z({type:"compileFinished"});let I={method:B.method,url:B.url,headers:B.headers??{},...B.body!==void 0?{body:B.body}:{}};if(Y){let j={request:I};await Y.triggerRequestCompiled({request:I,variables:A,ctx:D},j),I=j.request}if(Y)await Y.triggerRequestAfter({request:I,ctx:D});let{url:g,headers:n}=I,$G=Z?await Z.getCookieHeader(g):void 0,YG=Z?cG(n,$G):n,P;if(I.body!==void 0)if(I.body instanceof Buffer){let j=I.body,T=new ArrayBuffer(j.byteLength);new Uint8Array(T).set(new Uint8Array(j.buffer,j.byteOffset,j.byteLength)),P=T}else P=I.body;let q={method:I.method,url:I.url,headers:YG,...P!==void 0?{body:P}:{}};z({type:"fetchStarted",method:q.method,url:g});let XG=Date.now(),M;try{let j=E({}).ifDefined("timeout",V.timeoutMs).ifDefined("signal",V.signal).ifDefined("followRedirects",V.followRedirects).ifDefined("validateSSL",V.validateSSL).ifDefined("proxy",V.proxy).build();if(M=await s(q,j,K),z({type:"fetchFinished",method:q.method,url:g,status:M.status}),Z)await Z.setFromResponse(g,M)}catch(j){throw z({type:"error",stage:"fetch",message:j instanceof Error?j.message:String(j)}),j}let HG={total:Date.now()-XG},f;if(Y){let j={};if(await Y.triggerResponseAfter({request:I,response:M,timing:HG,ctx:D},j),f=j.retry,j.status!==void 0||j.statusText!==void 0||j.headers!==void 0||j.body!==void 0){let T=new Headers(M.headers);if(j.headers)for(let[JG,UG]of Object.entries(j.headers))T.set(JG,UG);let y=null;if(j.body!==void 0){if(typeof j.body==="string")y=j.body;else if(j.body instanceof Buffer)y=new Uint8Array(j.body);else if(j.body instanceof ReadableStream)y=j.body}M=new Response(y??M.body,{status:j.status??M.status,statusText:j.statusText??M.statusText,headers:T})}}return{response:M,...f!==void 0?{retry:f}:{}}}return{parseString:O,async runString(U,V={}){let{requests:C,basePath:D}=await w(U,V),_=QG(C,"No valid requests found in provided content.");return await N(_,V,D)},async runFile(U,V={}){let{requests:C,basePath:D}=await S(U,V),_=QG(C,`No valid requests found in file: ${U}`);return await N(_,V,D)}}}async function dG(G,K){let Q={...K.headerDefaults??{},...G.headers??{}},Z=G.body;if(G.bodyFile){let X=await x(G.bodyFile.path,E({basePath:K.basePath}).ifDefined("io",K.io).build());if(Z=X.content,!Q["Content-Type"]&&!Q["content-type"])Q["Content-Type"]=X.mimeType}else if(G.formData&&G.formData.length>0){if(a(G.formData))Z=await r(G.formData,E({basePath:K.basePath}).ifDefined("io",K.io).build()),delete Q["Content-Type"],delete Q["content-type"];else if(Z=t(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{hG as createEngine};
4
4
 
5
- //# debugId=E0954B635A34CF1964756E2164756E21
5
+ //# debugId=CD8C5D2973B8085164756E2164756E21
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 type { PluginManager } from '../plugin/manager';\nimport type {\n CompiledRequest,\n ErrorOutput,\n ParsedHttpFile,\n ResponseOutput,\n RetrySignal,\n TimingInfo\n} from '../plugin/types';\nimport { createAutoTransport } from '../runtime/auto-transport';\nimport type { CookieStore, EngineEvent, EventSink, IO, Transport } from '../runtime/types';\nimport type { ExecuteOptions, ExecuteRequest, FormField, ParsedRequest, 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 pluginManager?: PluginManager;\n maxRetries?: number;\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\n/**\n * Delay for retry.\n */\nfunction delay(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\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 const pluginManager = config.pluginManager;\n const maxRetries = config.maxRetries ?? 3;\n\n const interpolator = createInterpolator({ resolvers: config.resolvers ?? {} });\n\n // Helper to emit to both event sink and plugin manager\n function emitEvent(event: EngineEvent): void {\n emit(onEvent, event);\n pluginManager?.emitEngineEvent(event);\n }\n\n async function compileFromString(\n httpText: string,\n options: EngineRunOptions\n ): Promise<{\n requests: ParsedRequest[];\n filePath?: string;\n basePath: string;\n }> {\n emitEvent({ type: 'parseStarted', source: 'string' });\n const requests = parse(httpText);\n emitEvent({ type: 'parseFinished', source: 'string', requestCount: requests.length });\n\n const basePath =\n options.basePath ??\n io?.cwd() ??\n (globalThis as unknown as { process?: { cwd?: () => string } }).process?.cwd?.() ??\n '.';\n\n // Trigger parse.after hook if plugin manager exists\n if (pluginManager) {\n const parsedFile: ParsedHttpFile = {\n path: 'string',\n requests\n };\n const parseOutput = { file: parsedFile };\n await pluginManager.triggerParseAfter({ file: parsedFile, path: 'string' }, parseOutput);\n // Use potentially modified requests\n return { requests: parseOutput.file.requests, basePath };\n }\n\n return { requests, basePath };\n }\n\n async function compileFromFile(\n path: string,\n _options: EngineRunOptions\n ): Promise<{\n requests: ParsedRequest[];\n filePath: string;\n basePath: string;\n }> {\n emitEvent({ type: 'parseStarted', source: 'file' });\n const requests = await parseFileWithIO(path, io);\n emitEvent({ type: 'parseFinished', source: 'file', requestCount: requests.length });\n\n const basePath = getFileBasePath(path, io);\n\n // Trigger parse.after hook if plugin manager exists\n if (pluginManager) {\n const parsedFile: ParsedHttpFile = {\n path,\n requests\n };\n const parseOutput = { file: parsedFile };\n await pluginManager.triggerParseAfter({ file: parsedFile, path }, parseOutput);\n // Use potentially modified requests\n return { requests: parseOutput.file.requests, filePath: path, basePath };\n }\n\n return { requests, filePath: path, basePath };\n }\n\n async function processRequest(\n request: ParsedRequest,\n options: EngineRunOptions,\n basePath: string\n ): Promise<Response> {\n const variables = options.variables ?? {};\n let retries = 0;\n\n // Create hook context\n const createCtx = () =>\n pluginManager?.createHookContext({\n retries,\n maxRetries,\n variables\n }) ?? {\n retries,\n maxRetries,\n session: { id: 'default', variables: {} },\n variables,\n config: {\n projectRoot: '.',\n variables: {},\n security: { allowExternalFiles: false, allowPluginsOutsideProject: false }\n },\n projectRoot: '.'\n };\n\n // Retry loop\n while (true) {\n try {\n const result = await executeRequest(request, options, basePath, createCtx(), retries);\n\n // Check for retry signal\n if (result.retry && retries < maxRetries) {\n retries++;\n await delay(result.retry.delayMs);\n // Update cookies before retry (default behavior)\n continue;\n }\n\n return result.response;\n } catch (error) {\n // Handle error with error hook\n if (pluginManager) {\n const compiledRequest: CompiledRequest = {\n method: request.method,\n url: request.url,\n headers: request.headers,\n ...(request.body !== undefined ? { body: request.body } : {})\n };\n\n const errorOutput: ErrorOutput = {\n error: error instanceof Error ? error : new Error(String(error)),\n suppress: false\n };\n\n await pluginManager.triggerError(\n {\n request: compiledRequest,\n error: error instanceof Error ? error : new Error(String(error)),\n ctx: createCtx()\n },\n errorOutput\n );\n\n // Check for retry signal from error hook\n if (errorOutput.retry && retries < maxRetries) {\n retries++;\n await delay(errorOutput.retry.delayMs);\n continue;\n }\n\n // Suppress error if requested\n if (errorOutput.suppress) {\n // Return a synthetic error response\n return new Response(errorOutput.error.message, {\n status: 0,\n statusText: 'Suppressed Error'\n });\n }\n\n throw errorOutput.error;\n }\n\n throw error;\n }\n }\n }\n\n async function executeRequest(\n request: ParsedRequest,\n options: EngineRunOptions,\n basePath: string,\n ctx: ReturnType<\n typeof pluginManager extends undefined\n ? never\n : NonNullable<typeof pluginManager>['createHookContext']\n >,\n _retries: number\n ): Promise<{ response: Response; retry?: RetrySignal }> {\n // Step 1: request.before hook (before interpolation)\n let requestData: {\n method: string;\n url: string;\n headers: Record<string, string>;\n body?: string;\n } = {\n method: request.method,\n url: request.url,\n headers: { ...request.headers },\n ...(request.body !== undefined ? { body: request.body } : {})\n };\n\n if (pluginManager) {\n const beforeOutput = { request: requestData, skip: false };\n const result = await pluginManager.triggerRequestBefore(\n { request: requestData, variables: options.variables ?? {}, ctx },\n beforeOutput\n );\n\n if (result.skip) {\n // Return a synthetic \"skipped\" response (use 204 No Content as placeholder)\n return {\n response: new Response(null, { status: 204, statusText: 'Skipped by Plugin' })\n };\n }\n\n requestData = beforeOutput.request;\n }\n\n // Step 2: Interpolation\n emitEvent({ type: 'interpolateStarted' });\n const mergedVars = { ...(options.variables ?? {}) };\n const toInterpolate = {\n method: requestData.method,\n url: requestData.url,\n headers: requestData.headers,\n ...(requestData.body !== undefined ? { body: requestData.body } : {}),\n ...(request.name !== undefined ? { name: request.name } : {}),\n raw: request.raw,\n meta: request.meta,\n ...(request.bodyFile !== undefined ? { bodyFile: request.bodyFile } : {}),\n ...(request.formData !== undefined ? { formData: request.formData } : {})\n };\n const interpolated = await interpolator.interpolate(toInterpolate, mergedVars);\n emitEvent({ type: 'interpolateFinished' });\n\n // Step 3: Compile to ExecuteRequest\n emitEvent({ type: 'compileStarted' });\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 emitEvent({ type: 'compileFinished' });\n\n // Step 4: request.compiled hook (after interpolation, for signing)\n let compiledRequest: CompiledRequest = {\n method: executeRequest.method,\n url: executeRequest.url,\n headers: executeRequest.headers ?? {},\n ...(executeRequest.body !== undefined ? { body: executeRequest.body } : {})\n };\n\n if (pluginManager) {\n const compiledOutput = { request: compiledRequest };\n await pluginManager.triggerRequestCompiled(\n { request: compiledRequest, variables: mergedVars, ctx },\n compiledOutput\n );\n compiledRequest = compiledOutput.request;\n }\n\n // Step 5: request.after hook (read-only, logging/metrics)\n if (pluginManager) {\n await pluginManager.triggerRequestAfter({ request: compiledRequest, ctx });\n }\n\n // Step 6: Execute request\n const urlForCookies = compiledRequest.url;\n const headers = compiledRequest.headers;\n\n const cookieHeader = cookieStore ? await cookieStore.getCookieHeader(urlForCookies) : undefined;\n const headersWithCookies = cookieStore ? withCookieHeader(headers, cookieHeader) : headers;\n\n // Convert Buffer to ArrayBuffer for ExecuteRequest compatibility\n let bodyForRequest: ExecuteRequest['body'];\n if (compiledRequest.body !== undefined) {\n if (compiledRequest.body instanceof Buffer) {\n // Create a new ArrayBuffer from the Buffer's data\n const buf = compiledRequest.body;\n const arrayBuffer = new ArrayBuffer(buf.byteLength);\n new Uint8Array(arrayBuffer).set(new Uint8Array(buf.buffer, buf.byteOffset, buf.byteLength));\n bodyForRequest = arrayBuffer;\n } else {\n // Pass through string, ArrayBuffer, FormData, or URLSearchParams\n // Buffer is handled above, so this is safe\n bodyForRequest = compiledRequest.body as ExecuteRequest['body'];\n }\n }\n\n const requestWithCookies: ExecuteRequest = {\n method: compiledRequest.method,\n url: compiledRequest.url,\n headers: headersWithCookies,\n ...(bodyForRequest !== undefined ? { body: bodyForRequest } : {})\n };\n\n emitEvent({ type: 'fetchStarted', method: requestWithCookies.method, url: urlForCookies });\n\n const startTime = Date.now();\n let response: Response;\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 response = await executeWithTransport(requestWithCookies, execOptions, transport);\n\n emitEvent({\n type: 'fetchFinished',\n method: requestWithCookies.method,\n url: urlForCookies,\n status: response.status\n });\n\n // Update cookies\n if (cookieStore) {\n await cookieStore.setFromResponse(urlForCookies, response);\n }\n } catch (e) {\n emitEvent({\n type: 'error',\n stage: 'fetch',\n message: e instanceof Error ? e.message : String(e)\n });\n throw e;\n }\n\n const timing: TimingInfo = {\n total: Date.now() - startTime\n };\n\n // Step 7: response.after hook\n let retry: RetrySignal | undefined;\n\n if (pluginManager) {\n const responseOutput: ResponseOutput = {};\n await pluginManager.triggerResponseAfter(\n { request: compiledRequest, response, timing, ctx },\n responseOutput\n );\n\n retry = responseOutput.retry;\n\n // Reconstruct response if modified\n if (\n responseOutput.status !== undefined ||\n responseOutput.statusText !== undefined ||\n responseOutput.headers !== undefined ||\n responseOutput.body !== undefined\n ) {\n const newHeaders = new Headers(response.headers);\n if (responseOutput.headers) {\n for (const [key, value] of Object.entries(responseOutput.headers)) {\n newHeaders.set(key, value);\n }\n }\n\n let newBody: BodyInit | null = null;\n if (responseOutput.body !== undefined) {\n if (typeof responseOutput.body === 'string') {\n newBody = responseOutput.body;\n } else if (responseOutput.body instanceof Buffer) {\n // Convert Buffer to Uint8Array for BodyInit compatibility\n newBody = new Uint8Array(responseOutput.body);\n } else if (responseOutput.body instanceof ReadableStream) {\n newBody = responseOutput.body;\n }\n }\n\n response = new Response(newBody ?? response.body, {\n status: responseOutput.status ?? response.status,\n statusText: responseOutput.statusText ?? response.statusText,\n headers: newHeaders\n });\n }\n }\n\n return {\n response,\n ...(retry !== undefined ? { retry } : {})\n };\n }\n\n return {\n parseString: parse,\n async runString(httpText, options = {}) {\n const { requests, basePath } = await compileFromString(httpText, options);\n const request = firstOrThrow(requests, 'No valid requests found in provided content.');\n return await processRequest(request, options, basePath);\n },\n async runFile(path, options = {}) {\n const { requests, basePath } = await compileFromFile(path, options);\n const request = firstOrThrow(requests, `No valid requests found in file: ${path}`);\n return await processRequest(request, options, basePath);\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": "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",
16
+ "debugId": "CD8C5D2973B8085164756E2164756E21",
17
17
  "names": []
18
18
  }
package/dist/index.d.ts CHANGED
@@ -4,6 +4,10 @@ export { type FileLoaderOptions, inferMimeType, isBinaryMimeType, type LoadedFil
4
4
  export { type BuildFormDataOptions, buildFormData, buildUrlEncoded, hasFileFields } from './form-data-builder';
5
5
  export { createInterpolator, interpolate } from './interpolate';
6
6
  export { parse, parseFile, parseFileWithIO } from './parser';
7
+ export type { CombinedEvent, CombinedEventSink, CommandContext, CommandHandler, CompiledInput, CompiledOutput, CompiledRequest, EnterpriseContext, ErrorInput, ErrorOutput, HookContext, MiddlewareFunction, ParsedHttpFile, ParseInput, ParseOutput, PluginConfigRef, PluginEvent, PluginFactory, PluginHooks, PluginPermission, PluginPermissionsConfig, RequestAfterInput, RequestInput, RequestOutput, ResponseInput, ResponseOutput, RetrySignal, SubprocessPluginConfig, TimingInfo, ToolDefinition, ToolSchema, TreqPlugin } from './plugin';
8
+ export { createPluginManager, createRestrictedContext, definePlugin, getPluginId, loadPlugins, loadSubprocessPlugin, PermissionDeniedError, PluginManager, type PluginManagerOptions, parsePluginId, SubprocessPlugin, schema, tool } from './plugin';
7
9
  export { createAutoTransport, createFetchTransport } from './runtime';
10
+ export type { EngineEvent, EventSink } from './runtime/types';
11
+ export { getServerMetadata, type ServerMetadata } from './server-metadata';
8
12
  export type { Client, ClientConfig, ExecuteOptions, ExecuteRequest, FileReference, FormField, InterpolateOptions, Interpolator, ParsedRequest, Resolver, RunOptions } from './types';
9
13
  //# 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":"AACA,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;AAEhE,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE7D,YAAY,EACV,aAAa,EACb,iBAAiB,EACjB,cAAc,EAEd,cAAc,EACd,aAAa,EACb,cAAc,EACd,eAAe,EACf,iBAAiB,EACjB,UAAU,EACV,WAAW,EACX,WAAW,EACX,kBAAkB,EAClB,cAAc,EAEd,UAAU,EACV,WAAW,EACX,eAAe,EACf,WAAW,EACX,aAAa,EACb,WAAW,EACX,gBAAgB,EAChB,uBAAuB,EACvB,iBAAiB,EACjB,YAAY,EACZ,aAAa,EACb,aAAa,EACb,cAAc,EACd,WAAW,EACX,sBAAsB,EACtB,UAAU,EACV,cAAc,EACd,UAAU,EACV,UAAU,EACX,MAAM,UAAU,CAAC;AAElB,OAAO,EAEL,mBAAmB,EAEnB,uBAAuB,EAEvB,YAAY,EACZ,WAAW,EAEX,WAAW,EACX,oBAAoB,EACpB,qBAAqB,EACrB,aAAa,EACb,KAAK,oBAAoB,EACzB,aAAa,EAEb,gBAAgB,EAChB,MAAM,EACN,IAAI,EACL,MAAM,UAAU,CAAC;AAElB,OAAO,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AAEtE,YAAY,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE9D,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"}