@t-req/core 0.2.1 → 0.2.3
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.
- package/LICENSE +1 -1
- package/README.md +37 -2
- package/dist/config/index.js +6 -6
- package/dist/config/index.js.map +5 -5
- package/dist/engine/compile-request.d.ts +19 -0
- package/dist/engine/compile-request.d.ts.map +1 -0
- package/dist/engine/engine-utils.d.ts +13 -0
- package/dist/engine/engine-utils.d.ts.map +1 -0
- package/dist/engine/engine.d.ts +11 -1
- package/dist/engine/engine.d.ts.map +1 -1
- package/dist/engine/index.js +6 -4
- package/dist/engine/index.js.map +12 -6
- package/dist/engine/request-pipeline.d.ts +22 -0
- package/dist/engine/request-pipeline.d.ts.map +1 -0
- package/dist/index.d.ts +5 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +9 -7
- package/dist/index.js.map +16 -10
- package/dist/parser.d.ts +17 -1
- package/dist/parser.d.ts.map +1 -1
- package/dist/plugin/define.d.ts +3 -1
- package/dist/plugin/define.d.ts.map +1 -1
- package/dist/plugin/index.d.ts +1 -1
- package/dist/plugin/index.d.ts.map +1 -1
- package/dist/plugin/index.js +4 -4
- package/dist/plugin/index.js.map +5 -5
- package/dist/plugin/loader.d.ts.map +1 -1
- package/dist/plugin/manager.d.ts +29 -1
- package/dist/plugin/manager.d.ts.map +1 -1
- package/dist/plugin/types.d.ts +84 -0
- package/dist/plugin/types.d.ts.map +1 -1
- package/dist/protocols/http.d.ts +7 -0
- package/dist/protocols/http.d.ts.map +1 -0
- package/dist/protocols/index.d.ts +6 -0
- package/dist/protocols/index.d.ts.map +1 -0
- package/dist/protocols/registry.d.ts +24 -0
- package/dist/protocols/registry.d.ts.map +1 -0
- package/dist/protocols/sse.d.ts +26 -0
- package/dist/protocols/sse.d.ts.map +1 -0
- package/dist/protocols/types.d.ts +33 -0
- package/dist/protocols/types.d.ts.map +1 -0
- package/dist/runtime/types.d.ts +1 -0
- package/dist/runtime/types.d.ts.map +1 -1
- package/dist/server-client.d.ts.map +1 -1
- package/dist/types.d.ts +92 -1
- package/dist/types.d.ts.map +1 -1
- package/package.json +1 -1
package/dist/engine/index.js.map
CHANGED
|
@@ -1,18 +1,24 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../src/runtime/fetch-transport.ts", "../src/runtime/auto-transport.ts", "../src/utils/optional.ts", "../src/execute.ts", "../src/file-loader.ts", "../src/form-data-builder.ts", "../src/
|
|
3
|
+
"sources": ["../src/runtime/fetch-transport.ts", "../src/runtime/auto-transport.ts", "../src/utils/optional.ts", "../src/execute.ts", "../src/interpolate.ts", "../src/parser.ts", "../src/protocols/registry.ts", "../src/engine/engine-utils.ts", "../src/file-loader.ts", "../src/form-data-builder.ts", "../src/engine/compile-request.ts", "../src/engine/request-pipeline.ts", "../src/protocols/http.ts", "../src/protocols/sse.ts", "../src/engine/engine.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import type { Transport } from './types';\n\ntype FetchLike = (input: RequestInfo | URL, init?: RequestInit) => Promise<Response>;\n\nfunction unsupported(name: string): never {\n throw new Error(\n `${name} is not supported by this transport. Provide a transport that supports it.`\n );\n}\n\n/**\n * Create a minimal transport backed by a standard fetch implementation.\n * This transport is renderer-safe and works in Node 18+, Bun, and webviews.\n *\n * Note: proxy and validateSSL are not supported by baseline fetch.\n */\nexport function createFetchTransport(fetchImpl: FetchLike = fetch): Transport {\n return {\n capabilities: { proxy: false, validateSSL: false },\n async fetch(url, init, ctx) {\n if (ctx.proxy) unsupported('proxy');\n if (ctx.validateSSL === false) unsupported('validateSSL=false');\n return await fetchImpl(url, init);\n }\n };\n}\n",
|
|
6
6
|
"import { createFetchTransport } from './fetch-transport';\nimport type { Transport } from './types';\n\ntype BunFetchInit = RequestInit & { tls?: { rejectUnauthorized: boolean }; proxy?: string };\n\nfunction hasBun(): boolean {\n return typeof (globalThis as Record<string, unknown>)['Bun'] !== 'undefined';\n}\n\n/**\n * Auto-select a transport for the current runtime.\n *\n * - Bun: supports `proxy` and `validateSSL=false` via Bun fetch extensions.\n * - Others: falls back to baseline fetch transport (no proxy/validateSSL).\n */\nexport function createAutoTransport(): Transport {\n if (!hasBun()) {\n return createFetchTransport(fetch);\n }\n\n return {\n capabilities: { proxy: true, validateSSL: true },\n async fetch(url, init, ctx) {\n const bunInit: BunFetchInit = { ...(init ?? {}) };\n\n if (ctx.proxy !== undefined) {\n bunInit.proxy = ctx.proxy;\n }\n\n if (ctx.validateSSL === false) {\n bunInit.tls = { rejectUnauthorized: false };\n }\n\n return await fetch(url, bunInit);\n }\n };\n}\n",
|
|
7
7
|
"/**\n * A fluent builder for constructing objects with optional properties.\n * Eliminates verbose conditional spread patterns.\n */\nexport interface OptionalBuilder<T extends object> {\n /**\n * Add properties when a condition is true.\n */\n when<K extends keyof T>(condition: boolean, props: Pick<Required<T>, K>): OptionalBuilder<T>;\n\n /**\n * Add a property if its value is defined (not undefined).\n */\n ifDefined<K extends keyof T>(key: K, value: T[K] | undefined): OptionalBuilder<T>;\n\n /**\n * Return the built object.\n */\n build(): T;\n}\n\n/**\n * Create a fluent builder for constructing objects with optional properties.\n *\n * @example\n * ```typescript\n * // Instead of:\n * const obj = {\n * method,\n * url,\n * ...(body !== undefined && { body }),\n * ...(timeout !== undefined && { timeout })\n * };\n *\n * // Use:\n * const obj = setOptional<Request>({ method, url })\n * .ifDefined('body', body)\n * .ifDefined('timeout', timeout)\n * .build();\n * ```\n */\nexport function setOptional<T extends object>(base: T): OptionalBuilder<T> {\n let result = { ...base };\n\n const builder: OptionalBuilder<T> = {\n when(condition, props) {\n if (condition) {\n result = { ...result, ...props };\n }\n return builder;\n },\n\n ifDefined(key, value) {\n if (value !== undefined) {\n result = { ...result, [key]: value };\n }\n return builder;\n },\n\n build() {\n return result;\n }\n };\n\n return builder;\n}\n",
|
|
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
|
+
"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",
|
|
10
|
+
"import type { IO } from './runtime/types';\nimport type {\n Directive,\n FileReference,\n FormField,\n ParsedDocument,\n ParsedRequest,\n Protocol,\n ProtocolOptions,\n SSEOptions\n} 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// Pattern to match file-level variables: @varName = value\n// Requires `=` sign to avoid collision with bare directives like `@timeout 5000`\nconst FILE_VARIABLE_PATTERN = /^@([A-Za-z_][\\w.]*)\\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 * Detect protocol from meta directives and headers.\n * Priority: explicit directive > Accept header > default HTTP\n */\nfunction detectProtocol(\n headers: Record<string, string>,\n meta: Record<string, string>\n): { protocol: Protocol; protocolOptions?: ProtocolOptions } {\n // Priority 1: Explicit @sse directive\n if (meta['sse'] !== undefined) {\n const options: SSEOptions = { type: 'sse' };\n\n // Parse optional timeout from meta\n if (meta['timeout']) {\n const timeout = parseInt(meta['timeout'], 10);\n if (!Number.isNaN(timeout)) {\n options.timeout = timeout;\n }\n }\n\n // Parse optional lastEventId from meta\n if (meta['lastEventId']) {\n options.lastEventId = meta['lastEventId'];\n }\n\n return { protocol: 'sse', protocolOptions: options };\n }\n\n // Priority 2: Auto-detect from Accept header\n const accept = headers['Accept'] || headers['accept'];\n if (accept?.includes('text/event-stream')) {\n return { protocol: 'sse', protocolOptions: { type: 'sse' } };\n }\n\n // Default: HTTP\n return { protocol: 'http' };\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 const directives: Directive[] = [];\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 if (directive) {\n directives.push({ name: directive, value: value?.trim() || '', line: i });\n }\n }\n continue;\n }\n\n // Parse request line (METHOD URL HTTP/VERSION)\n if (!requestLineFound) {\n const fullMatch = trimmedLine.match(\n /^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\\s+(\\S+)(\\s+HTTP\\/[\\d.]+)?$/i\n );\n if (fullMatch) {\n const [, m, u] = fullMatch;\n if (!m || !u) continue;\n method = m.toUpperCase();\n url = u;\n requestLineFound = true;\n }\n\n if (!requestLineFound) {\n const simpleMatch = trimmedLine.match(\n /^(GET|POST|PUT|DELETE|PATCH|HEAD|OPTIONS|TRACE|CONNECT)\\s+(.+)$/i\n );\n if (simpleMatch) {\n const [, m, u] = simpleMatch;\n if (!m || !u) continue;\n method = m.toUpperCase();\n url = u.trim();\n requestLineFound = true;\n }\n }\n\n if (requestLineFound) {\n // Consume URL continuation lines (?/& prefix)\n while (i + 1 < lines.length) {\n const nextLine = lines[i + 1]?.trim();\n if (nextLine && (nextLine.startsWith('?') || nextLine.startsWith('&'))) {\n url += nextLine;\n i++;\n } else {\n break;\n }\n }\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 // Detect protocol from meta directives and headers\n const { protocol, protocolOptions } = detectProtocol(headers, meta);\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 .ifDefined('directives', directives.length > 0 ? directives : undefined)\n .ifDefined('protocol', protocol !== 'http' ? protocol : undefined)\n .ifDefined('protocolOptions', protocolOptions?.type !== undefined ? protocolOptions : undefined)\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\n/**\n * Extract file-level variables (@var = value) from raw content.\n * Returns the variables and the cleaned content with variable lines removed.\n */\nfunction extractFileVariables(content: string): {\n fileVariables: Record<string, string>;\n cleanedContent: string;\n} {\n const fileVariables: Record<string, string> = {};\n const lines = content.split(/\\r?\\n/);\n const cleanedLines: string[] = [];\n\n for (const line of lines) {\n const match = line.trim().match(FILE_VARIABLE_PATTERN);\n if (match) {\n const [, name, value] = match;\n if (name && value !== undefined) {\n fileVariables[name] = value.trim();\n }\n } else {\n cleanedLines.push(line);\n }\n }\n\n return { fileVariables, cleanedContent: cleanedLines.join('\\n') };\n}\n\n/**\n * Parse .http file content into a full document with file-level variables.\n *\n * File variables use `@var = value` syntax and are extracted before\n * request block parsing. They are available to all requests in the document.\n */\nexport function parseDocument(content: string): ParsedDocument {\n const { fileVariables, cleanedContent } = extractFileVariables(content);\n const requests = parse(cleanedContent);\n return { requests, fileVariables };\n}\n\n/**\n * Parse .http file from filesystem into a full document with file-level variables.\n */\nexport async function parseDocumentFile(path: string): Promise<ParsedDocument> {\n return await parseDocumentFileWithIO(path);\n}\n\n/**\n * Parse .http file from filesystem into a full document using an IO adapter.\n * If `io` is omitted, Bun runtime fallback is used when available.\n */\nexport async function parseDocumentFileWithIO(path: string, io?: IO): Promise<ParsedDocument> {\n if (io) {\n const content = await io.readText(path);\n return parseDocument(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 parseDocument(content);\n }\n\n throw new Error('No IO adapter provided. Use parseDocumentFileWithIO(path, io) in this runtime.');\n}\n",
|
|
11
|
+
"import type { Protocol, ProtocolHandler } from './types';\n\n/**\n * Registry of protocol handlers.\n * Handlers register themselves on import.\n */\nconst handlers = new Map<Protocol, ProtocolHandler>();\n\n/**\n * Register a protocol handler.\n * Called by each handler module on import.\n */\nexport function registerProtocol(handler: ProtocolHandler): void {\n handlers.set(handler.protocol, handler);\n}\n\n/**\n * Get a handler for a specific protocol.\n */\nexport function getHandler(protocol: Protocol): ProtocolHandler | undefined {\n return handlers.get(protocol);\n}\n\n/**\n * Get the default HTTP handler.\n * Throws if HTTP handler is not registered (should never happen).\n */\nexport function getDefaultHandler(): ProtocolHandler {\n const handler = handlers.get('http');\n if (!handler) {\n throw new Error('HTTP handler not registered. Import the http protocol handler.');\n }\n return handler;\n}\n\n/**\n * Check if a protocol handler is registered.\n */\nexport function hasHandler(protocol: Protocol): boolean {\n return handlers.has(protocol);\n}\n\n/**\n * Get all registered protocol names.\n */\nexport function getRegisteredProtocols(): Protocol[] {\n return Array.from(handlers.keys());\n}\n",
|
|
12
|
+
"import type { EngineEvent, EventSink, IO } from '../runtime/types';\n\nexport function emit(onEvent: EventSink | undefined, event: EngineEvent): void {\n onEvent?.(event);\n}\n\nexport function 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\nexport function 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\nexport function 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\nexport function 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\nexport function 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\nexport function 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 */\nexport function delay(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n",
|
|
9
13
|
"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
14
|
"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
|
|
12
|
-
"import type {
|
|
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"
|
|
15
|
+
"import { loadFileBody } from '../file-loader';\nimport { buildFormData, buildUrlEncoded, hasFileFields } from '../form-data-builder';\nimport type { IO } from '../runtime/types';\nimport type { ExecuteRequest, FormField } from '../types';\nimport { setOptional } from '../utils/optional';\n\nexport async 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",
|
|
16
|
+
"import type { createInterpolator } from '../interpolate';\nimport type { PluginManager } from '../plugin/manager';\nimport type { CompiledRequest, HookContext } from '../plugin/types';\nimport type { CookieStore, EngineEvent, IO } from '../runtime/types';\nimport type { ExecuteRequest, ParsedRequest } from '../types';\nimport { setOptional } from '../utils/optional';\nimport { compileExecuteRequest } from './compile-request';\nimport { withCookieHeader } from './engine-utils';\n\nexport type PipelineConfig = {\n interpolator: ReturnType<typeof createInterpolator>;\n cookieStore?: CookieStore;\n headerDefaults?: Record<string, string>;\n io?: IO;\n pluginManager?: PluginManager;\n emitEvent: (event: EngineEvent) => void;\n};\n\nexport type PreparedRequest = {\n compiledRequest: CompiledRequest;\n requestWithCookies: ExecuteRequest;\n urlForCookies: string;\n mergedVars: Record<string, unknown>;\n skipped: boolean;\n};\n\nexport async function prepareRequest(\n config: PipelineConfig,\n request: ParsedRequest,\n variables: Record<string, unknown>,\n basePath: string,\n hookCtx: HookContext\n): Promise<PreparedRequest> {\n const { interpolator, cookieStore, headerDefaults, io, pluginManager, emitEvent } = config;\n\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, ctx: hookCtx },\n beforeOutput\n );\n\n if (result.skip) {\n // Return a skipped result — caller decides what to do\n return {\n compiledRequest: {\n method: requestData.method,\n url: requestData.url,\n headers: requestData.headers\n },\n requestWithCookies: {\n method: requestData.method,\n url: requestData.url,\n headers: requestData.headers\n },\n urlForCookies: requestData.url,\n mergedVars: { ...variables },\n skipped: true\n };\n }\n\n requestData = beforeOutput.request;\n }\n\n // Step 2: Interpolation\n emitEvent({ type: 'interpolateStarted' });\n const mergedVars = { ...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 ...(request.directives !== undefined ? { directives: request.directives } : {})\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: compiledExecReq } = 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: compiledExecReq.method,\n url: compiledExecReq.url,\n headers: compiledExecReq.headers ?? {},\n ...(compiledExecReq.body !== undefined ? { body: compiledExecReq.body } : {}),\n ...(interpolated.name !== undefined ? { name: interpolated.name } : {}),\n ...(interpolated.meta !== undefined ? { meta: interpolated.meta } : {}),\n ...(interpolated.directives !== undefined ? { directives: interpolated.directives } : {})\n };\n\n if (pluginManager) {\n const compiledOutput = { request: compiledRequest };\n await pluginManager.triggerRequestCompiled(\n { request: compiledRequest, variables: mergedVars, ctx: hookCtx },\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: hookCtx });\n }\n\n // Step 6: Cookie injection + body conversion\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 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 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 return {\n compiledRequest,\n requestWithCookies,\n urlForCookies,\n mergedVars,\n skipped: false\n };\n}\n",
|
|
17
|
+
"import { executeWithTransport } from '../execute';\nimport type { ParsedRequest } from '../types';\nimport { registerProtocol } from './registry';\nimport type { ProtocolExecuteOptions, ProtocolHandler } from './types';\n\n/**\n * HTTP protocol handler.\n * Handles standard HTTP request/response cycle.\n */\nexport const httpHandler: ProtocolHandler = {\n protocol: 'http',\n\n canHandle(request: ParsedRequest): boolean {\n // HTTP is the default - handles requests without explicit protocol\n // or with explicit 'http' protocol\n return !request.protocol || request.protocol === 'http';\n },\n\n async execute(request, options, transport): Promise<Response> {\n // Build execute options without protocol-specific fields\n // Filter out undefined values to satisfy exactOptionalPropertyTypes\n const execOptions: ProtocolExecuteOptions = {};\n if (options.timeout !== undefined) execOptions.timeout = options.timeout;\n if (options.signal !== undefined) execOptions.signal = options.signal;\n if (options.followRedirects !== undefined)\n execOptions.followRedirects = options.followRedirects;\n if (options.validateSSL !== undefined) execOptions.validateSSL = options.validateSSL;\n if (options.proxy !== undefined) execOptions.proxy = options.proxy;\n\n return executeWithTransport(request, execOptions, transport);\n }\n};\n\n// Register the handler on module load\nregisterProtocol(httpHandler);\n",
|
|
18
|
+
"import type { Transport, TransportContext } from '../runtime/types';\nimport type { ExecuteRequest, ParsedRequest, SSEMessage, SSEResponse } from '../types';\nimport { setOptional } from '../utils/optional';\nimport { registerProtocol } from './registry';\nimport type { ProtocolExecuteOptions, ProtocolHandler } from './types';\n\n/**\n * Parse an SSE stream from a ReadableStreamDefaultReader.\n * Yields SSEMessage objects as they are received.\n *\n * SSE format:\n * event: <type>\n * id: <id>\n * data: <payload>\n * retry: <ms>\n * <blank line> (message boundary)\n * : comment (ignored, used for keep-alive)\n */\nasync function* parseSSEStream(\n reader: ReadableStreamDefaultReader<Uint8Array>\n): AsyncGenerator<SSEMessage, void, unknown> {\n const decoder = new TextDecoder();\n let buffer = '';\n let currentMessage: Partial<SSEMessage> = {};\n\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n\n buffer += decoder.decode(value, { stream: true });\n const lines = buffer.split(/\\r?\\n/);\n buffer = lines.pop() ?? '';\n\n for (const line of lines) {\n if (line.startsWith('id:')) {\n currentMessage.id = line.slice(3).trim();\n } else if (line.startsWith('event:')) {\n currentMessage.event = line.slice(6).trim();\n } else if (line.startsWith('data:')) {\n // Data can be multi-line - concatenate with newline\n const data = line.slice(5);\n currentMessage.data =\n currentMessage.data !== undefined ? `${currentMessage.data}\\n${data}` : data;\n } else if (line.startsWith('retry:')) {\n const retryValue = parseInt(line.slice(6).trim(), 10);\n if (!Number.isNaN(retryValue)) {\n currentMessage.retry = retryValue;\n }\n } else if (line === '') {\n // Empty line = end of message\n if (currentMessage.data !== undefined) {\n yield currentMessage as SSEMessage;\n }\n currentMessage = {};\n }\n // Lines starting with ':' are comments (keep-alive), ignore them\n }\n }\n\n // Flush any remaining message if stream ended mid-message\n if (currentMessage.data !== undefined) {\n yield currentMessage as SSEMessage;\n }\n}\n\n/**\n * Create an SSEResponse wrapper around a fetch Response.\n */\nfunction createSSEResponse(response: Response): SSEResponse {\n if (!response.body) {\n throw new Error('SSE response has no body');\n }\n\n const reader = response.body.getReader();\n let closed = false;\n\n const generator = parseSSEStream(reader);\n\n const sseResponse: SSEResponse = {\n type: 'sse',\n\n async *[Symbol.asyncIterator](): AsyncGenerator<SSEMessage, void, unknown> {\n if (closed) return;\n\n for await (const message of generator) {\n if (closed) return;\n\n // Track last event ID for resumption\n if (message.id) {\n // Update the property on the response object\n (sseResponse as { lastEventId?: string }).lastEventId = message.id;\n }\n\n yield message;\n }\n },\n\n close(): void {\n if (closed) return;\n closed = true;\n reader.cancel().catch(() => {\n // Ignore cancel errors\n });\n },\n\n response\n };\n\n return sseResponse;\n}\n\n/**\n * SSE protocol handler.\n * Handles Server-Sent Events streaming connections.\n */\nexport const sseHandler: ProtocolHandler = {\n protocol: 'sse',\n\n canHandle(request: ParsedRequest): boolean {\n // Explicit @sse directive\n if (request.protocol === 'sse') {\n return true;\n }\n\n // Auto-detect from Accept header\n const accept = request.headers['Accept'] || request.headers['accept'];\n if (accept?.includes('text/event-stream')) {\n return true;\n }\n\n return false;\n },\n\n async execute(\n request: ExecuteRequest,\n options: ProtocolExecuteOptions,\n transport: Transport\n ): Promise<SSEResponse> {\n // Build SSE-specific headers\n const headers: Record<string, string> = {\n ...request.headers,\n Accept: 'text/event-stream',\n 'Cache-Control': 'no-cache'\n };\n\n // Add Last-Event-ID for resumption\n if (options.lastEventId) {\n headers['Last-Event-ID'] = options.lastEventId;\n }\n\n // Build transport context\n const ctx = setOptional<TransportContext>({})\n .ifDefined('proxy', options.proxy)\n .ifDefined('validateSSL', options.validateSSL)\n .build();\n\n // Build request init - only include signal if defined\n const requestInit: RequestInit = {\n method: request.method || 'GET',\n headers\n };\n if (options.signal) {\n requestInit.signal = options.signal;\n }\n\n // Execute the request\n const response = await transport.fetch(request.url, requestInit, ctx);\n\n // Verify response is SSE\n const contentType = response.headers.get('content-type') ?? '';\n if (!contentType.includes('text/event-stream') && response.ok) {\n // Response is OK but not SSE - might be an error page or redirect\n // Let it through but log a warning via the response\n }\n\n if (!response.ok) {\n throw new Error(`SSE request failed: ${response.status} ${response.statusText}`);\n }\n\n return createSSEResponse(response);\n }\n};\n\n// Register the handler on module load\nregisterProtocol(sseHandler);\n\n// Export utilities for SDK use\nexport { createSSEResponse, parseSSEStream };\n",
|
|
19
|
+
"import { executeWithTransport } from '../execute';\nimport { createInterpolator } from '../interpolate';\nimport { parse, parseDocument, parseDocumentFileWithIO } from '../parser';\nimport type { PluginManager } from '../plugin/manager';\nimport type {\n CompiledRequest,\n ErrorOutput,\n HookContext,\n ParsedHttpFile,\n ResponseOutput,\n RetrySignal,\n TimingInfo\n} from '../plugin/types';\nimport { getHandler } from '../protocols/registry';\nimport type { Protocol, ProtocolExecuteOptions } from '../protocols/types';\nimport { createAutoTransport } from '../runtime/auto-transport';\nimport type { CookieStore, EngineEvent, EventSink, IO, Transport } from '../runtime/types';\nimport type {\n ExecuteOptions,\n ParsedRequest,\n Protocol as ProtocolType,\n Resolver,\n StreamResponse\n} from '../types';\nimport { setOptional } from '../utils/optional';\nimport { delay, emit, firstOrThrow, getFileBasePath } from './engine-utils';\nimport { type PipelineConfig, prepareRequest } from './request-pipeline';\n\n// Import protocol handlers for side-effect registration\nimport '../protocols/http';\nimport '../protocols/sse';\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 /** Force specific protocol (overrides auto-detection) */\n protocol?: ProtocolType;\n /** Last-Event-ID for SSE resumption */\n lastEventId?: 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 /** Execute a streaming request (SSE, WebSocket, etc.) from string content */\n streamString: (httpText: string, options?: EngineRunOptions) => Promise<StreamResponse>;\n /** Execute a streaming request (SSE, WebSocket, etc.) from a file */\n streamFile: (path: string, options?: EngineRunOptions) => Promise<StreamResponse>;\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 // Build pipeline config conditionally to handle exactOptionalPropertyTypes\n const pipelineConfig: PipelineConfig = { interpolator, emitEvent };\n if (cookieStore) pipelineConfig.cookieStore = cookieStore;\n if (headerDefaults) pipelineConfig.headerDefaults = headerDefaults;\n if (io) pipelineConfig.io = io;\n if (pluginManager) pipelineConfig.pluginManager = pluginManager;\n\n function createHookCtx(retries: number, variables: Record<string, unknown>): HookContext {\n return (\n pluginManager?.createHookContext({\n retries,\n maxRetries,\n variables\n }) ?? {\n retries,\n maxRetries,\n session: { id: 'default', variables: {}, reports: [] },\n variables,\n config: {\n projectRoot: '.',\n variables: {},\n security: { allowExternalFiles: false, allowPluginsOutsideProject: false }\n },\n projectRoot: '.',\n report: () => {}\n }\n );\n }\n\n async function compileFromString(\n httpText: string,\n options: EngineRunOptions\n ): Promise<{\n requests: ParsedRequest[];\n fileVariables: Record<string, string>;\n filePath?: string;\n basePath: string;\n }> {\n emitEvent({ type: 'parseStarted', source: 'string' });\n const { requests, fileVariables } = parseDocument(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, fileVariables, basePath };\n }\n\n return { requests, fileVariables, basePath };\n }\n\n async function compileFromFile(\n path: string,\n _options: EngineRunOptions\n ): Promise<{\n requests: ParsedRequest[];\n fileVariables: Record<string, string>;\n filePath: string;\n basePath: string;\n }> {\n emitEvent({ type: 'parseStarted', source: 'file' });\n const { requests, fileVariables } = await parseDocumentFileWithIO(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, fileVariables, filePath: path, basePath };\n }\n\n return { requests, fileVariables, filePath: path, basePath };\n }\n\n async function processRequest(\n request: ParsedRequest,\n options: EngineRunOptions,\n basePath: string,\n fileVariables: Record<string, string> = {}\n ): Promise<Response> {\n const variables = { ...fileVariables, ...(options.variables ?? {}) };\n let retries = 0;\n\n // Retry loop\n while (true) {\n try {\n const hookCtx = createHookCtx(retries, variables);\n const prepared = await prepareRequest(\n pipelineConfig,\n request,\n variables,\n basePath,\n hookCtx\n );\n\n if (prepared.skipped) {\n return new Response(null, { status: 204, statusText: 'Skipped by Plugin' });\n }\n\n // Execute the fetch\n emitEvent({\n type: 'fetchStarted',\n method: prepared.requestWithCookies.method,\n url: prepared.urlForCookies\n });\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 const fetchStart = performance.now();\n response = await executeWithTransport(\n prepared.requestWithCookies,\n execOptions,\n transport\n );\n const ttfb = performance.now() - fetchStart;\n\n emitEvent({\n type: 'fetchFinished',\n method: prepared.requestWithCookies.method,\n url: prepared.urlForCookies,\n status: response.status,\n ttfb\n });\n\n // Update cookies\n if (cookieStore) {\n await cookieStore.setFromResponse(prepared.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 // response.after hook\n let retry: RetrySignal | undefined;\n\n if (pluginManager) {\n const responseOutput: ResponseOutput = {};\n await pluginManager.triggerResponseAfter(\n { request: prepared.compiledRequest, response, timing, ctx: hookCtx },\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 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 // Check for retry signal\n if (retry && retries < maxRetries) {\n retries++;\n await delay(retry.delayMs);\n continue;\n }\n\n return 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 ...(request.name !== undefined ? { name: request.name } : {}),\n ...(request.meta !== undefined ? { meta: request.meta } : {}),\n ...(request.directives !== undefined ? { directives: request.directives } : {})\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: createHookCtx(retries, variables)\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 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 /**\n * Compile a request and execute it via the appropriate protocol handler for streaming.\n */\n async function processStreamRequest(\n request: ParsedRequest,\n options: EngineRunOptions,\n basePath: string,\n fileVariables: Record<string, string> = {}\n ): Promise<StreamResponse> {\n // Determine protocol (explicit override > parsed > error)\n const protocol: Protocol = (options.protocol ?? request.protocol ?? 'http') as Protocol;\n\n // Validate this is a streaming protocol\n if (protocol === 'http') {\n throw new Error(\n `Request protocol is 'http' but expected a streaming protocol (sse, ws). ` +\n `Use runString() for HTTP requests or add @sse directive.`\n );\n }\n\n const handler = getHandler(protocol);\n if (!handler) {\n throw new Error(`No handler registered for protocol: ${protocol}`);\n }\n\n const variables = { ...fileVariables, ...(options.variables ?? {}) };\n const hookCtx = createHookCtx(0, variables);\n const prepared = await prepareRequest(pipelineConfig, request, variables, basePath, hookCtx);\n\n if (prepared.skipped) {\n throw new Error('Request skipped by plugin - cannot stream a skipped request');\n }\n\n emitEvent({\n type: 'fetchStarted',\n method: prepared.requestWithCookies.method,\n url: prepared.urlForCookies\n });\n\n // Build protocol-specific options\n const execOptions: ProtocolExecuteOptions = setOptional<ProtocolExecuteOptions>({})\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 .ifDefined('lastEventId', options.lastEventId ?? request.protocolOptions?.lastEventId)\n .build();\n\n try {\n const result = await handler.execute(prepared.requestWithCookies, execOptions, transport);\n return result as StreamResponse;\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\n return {\n parseString: parse,\n async runString(httpText, options = {}) {\n const { requests, fileVariables, basePath } = await compileFromString(httpText, options);\n const request = firstOrThrow(requests, 'No valid requests found in provided content.');\n return await processRequest(request, options, basePath, fileVariables);\n },\n async runFile(path, options = {}) {\n const { requests, fileVariables, basePath } = await compileFromFile(path, options);\n const request = firstOrThrow(requests, `No valid requests found in file: ${path}`);\n return await processRequest(request, options, basePath, fileVariables);\n },\n async streamString(httpText, options = {}) {\n const { requests, fileVariables, basePath } = await compileFromString(httpText, options);\n const request = firstOrThrow(requests, 'No valid requests found in provided content.');\n return await processStreamRequest(request, options, basePath, fileVariables);\n },\n async streamFile(path, options = {}) {\n const { requests, fileVariables, basePath } = await compileFromFile(path, options);\n const request = firstOrThrow(requests, `No valid requests found in file: ${path}`);\n return await processStreamRequest(request, options, basePath, fileVariables);\n }\n };\n}\n"
|
|
14
20
|
],
|
|
15
|
-
"mappings": "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",
|
|
16
|
-
"debugId": "
|
|
21
|
+
"mappings": "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",
|
|
22
|
+
"debugId": "8416C10E2C8D9DA764756E2164756E21",
|
|
17
23
|
"names": []
|
|
18
24
|
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { createInterpolator } from '../interpolate';
|
|
2
|
+
import type { PluginManager } from '../plugin/manager';
|
|
3
|
+
import type { CompiledRequest, HookContext } from '../plugin/types';
|
|
4
|
+
import type { CookieStore, EngineEvent, IO } from '../runtime/types';
|
|
5
|
+
import type { ExecuteRequest, ParsedRequest } from '../types';
|
|
6
|
+
export type PipelineConfig = {
|
|
7
|
+
interpolator: ReturnType<typeof createInterpolator>;
|
|
8
|
+
cookieStore?: CookieStore;
|
|
9
|
+
headerDefaults?: Record<string, string>;
|
|
10
|
+
io?: IO;
|
|
11
|
+
pluginManager?: PluginManager;
|
|
12
|
+
emitEvent: (event: EngineEvent) => void;
|
|
13
|
+
};
|
|
14
|
+
export type PreparedRequest = {
|
|
15
|
+
compiledRequest: CompiledRequest;
|
|
16
|
+
requestWithCookies: ExecuteRequest;
|
|
17
|
+
urlForCookies: string;
|
|
18
|
+
mergedVars: Record<string, unknown>;
|
|
19
|
+
skipped: boolean;
|
|
20
|
+
};
|
|
21
|
+
export declare function prepareRequest(config: PipelineConfig, request: ParsedRequest, variables: Record<string, unknown>, basePath: string, hookCtx: HookContext): Promise<PreparedRequest>;
|
|
22
|
+
//# sourceMappingURL=request-pipeline.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-pipeline.d.ts","sourceRoot":"","sources":["../../src/engine/request-pipeline.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,KAAK,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AACpE,OAAO,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAC;AACrE,OAAO,KAAK,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAK9D,MAAM,MAAM,cAAc,GAAG;IAC3B,YAAY,EAAE,UAAU,CAAC,OAAO,kBAAkB,CAAC,CAAC;IACpD,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACxC,EAAE,CAAC,EAAE,EAAE,CAAC;IACR,aAAa,CAAC,EAAE,aAAa,CAAC;IAC9B,SAAS,EAAE,CAAC,KAAK,EAAE,WAAW,KAAK,IAAI,CAAC;CACzC,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,eAAe,EAAE,eAAe,CAAC;IACjC,kBAAkB,EAAE,cAAc,CAAC;IACnC,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACpC,OAAO,EAAE,OAAO,CAAC;CAClB,CAAC;AAEF,wBAAsB,cAAc,CAClC,MAAM,EAAE,cAAc,EACtB,OAAO,EAAE,aAAa,EACtB,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAClC,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,WAAW,GACnB,OAAO,CAAC,eAAe,CAAC,CAuI1B"}
|
package/dist/index.d.ts
CHANGED
|
@@ -3,11 +3,13 @@ export { createEngine } from './engine/engine';
|
|
|
3
3
|
export { type FileLoaderOptions, inferMimeType, isBinaryMimeType, type LoadedFile, loadFileBody, validateFilePath } from './file-loader';
|
|
4
4
|
export { type BuildFormDataOptions, buildFormData, buildUrlEncoded, hasFileFields } from './form-data-builder';
|
|
5
5
|
export { createInterpolator, interpolate } from './interpolate';
|
|
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';
|
|
6
|
+
export { parse, parseDocument, parseDocumentFile, parseDocumentFileWithIO, parseFile, parseFileWithIO } from './parser';
|
|
7
|
+
export type { CombinedEvent, CombinedEventSink, CommandContext, CommandHandler, CompiledInput, CompiledOutput, CompiledRequest, EnterpriseContext, ErrorInput, ErrorOutput, HookContext, MiddlewareFunction, ParsedHttpFile, ParseInput, ParseOutput, PluginConfigRef, PluginDiagnostic, PluginEvent, PluginFactory, PluginHooks, PluginPermission, PluginPermissionsConfig, PluginReport, RequestAfterInput, RequestInput, RequestOutput, ResponseInput, ResponseOutput, RetrySignal, SubprocessPluginConfig, TimingInfo, ToolDefinition, ToolSchema, TreqPlugin, ValidateInput, ValidateOutput } from './plugin';
|
|
8
8
|
export { createPluginManager, createRestrictedContext, definePlugin, getPluginId, loadPlugins, loadSubprocessPlugin, PermissionDeniedError, PluginManager, type PluginManagerOptions, parsePluginId, SubprocessPlugin, schema, tool } from './plugin';
|
|
9
|
+
export type { Protocol, ProtocolExecuteOptions, ProtocolHandler } from './protocols';
|
|
10
|
+
export { getDefaultHandler, getHandler, getRegisteredProtocols, hasHandler, httpHandler, registerProtocol, sseHandler } from './protocols';
|
|
9
11
|
export { createAutoTransport, createFetchTransport } from './runtime';
|
|
10
12
|
export type { EngineEvent, EventSink } from './runtime/types';
|
|
11
13
|
export { getServerMetadata, type ServerMetadata } from './server-metadata';
|
|
12
|
-
export type { Client, ClientConfig, ExecuteOptions, ExecuteRequest, FileReference, FormField, InterpolateOptions, Interpolator, ParsedRequest, Resolver, RunOptions } from './types';
|
|
14
|
+
export type { Client, ClientConfig, Directive, ExecuteOptions, ExecuteRequest, FileReference, FormField, InterpolateOptions, Interpolator, ParsedDocument, ParsedRequest, Protocol as ProtocolType, ProtocolOptions, Resolver, RunOptions, SSEMessage, SSEOptions, SSEResponse, StreamResponse } from './types';
|
|
13
15
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
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,
|
|
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,EACL,KAAK,EACL,aAAa,EACb,iBAAiB,EACjB,uBAAuB,EACvB,SAAS,EACT,eAAe,EAChB,MAAM,UAAU,CAAC;AAElB,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,gBAAgB,EAChB,WAAW,EACX,aAAa,EACb,WAAW,EACX,gBAAgB,EAChB,uBAAuB,EACvB,YAAY,EACZ,iBAAiB,EACjB,YAAY,EACZ,aAAa,EACb,aAAa,EACb,cAAc,EACd,WAAW,EACX,sBAAsB,EACtB,UAAU,EACV,cAAc,EACd,UAAU,EACV,UAAU,EACV,aAAa,EACb,cAAc,EACf,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;AAClB,YAAY,EAAE,QAAQ,EAAE,sBAAsB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAErF,OAAO,EACL,iBAAiB,EACjB,UAAU,EACV,sBAAsB,EACtB,UAAU,EACV,WAAW,EACX,gBAAgB,EAChB,UAAU,EACX,MAAM,aAAa,CAAC;AAErB,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,SAAS,EACT,cAAc,EACd,cAAc,EACd,aAAa,EACb,SAAS,EACT,kBAAkB,EAClB,YAAY,EACZ,cAAc,EACd,aAAa,EACb,QAAQ,IAAI,YAAY,EACxB,eAAe,EACf,QAAQ,EACR,UAAU,EACV,UAAU,EACV,UAAU,EACV,WAAW,EACX,cAAc,EACf,MAAM,SAAS,CAAC"}
|