@oazapfts/runtime 0.0.1-start

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/README.md ADDED
@@ -0,0 +1,7 @@
1
+ # @oazapfts/runtime
2
+
3
+ Runtime for OpenAPI clients generated by [oazapfts](https://www.npmjs.com/package/oazapfts).
4
+
5
+ # License
6
+
7
+ MIT
@@ -0,0 +1,2 @@
1
+ function a(e,r){let n=t(e);return t(r).forEach((s,i)=>{n.set(i,s)}),n}function t(e){return e&&!(e instanceof Headers)&&!Array.isArray(e)?new Headers(Object.fromEntries(Object.entries(e).filter(([,r])=>r!=null).map(([r,n])=>[r,String(n)]))):new Headers(e)}export{a,t as b};
2
+ //# sourceMappingURL=chunk-6C7A2H7M.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/headers.ts"],
4
+ "sourcesContent": ["export type CustomHeaders = Record<\n string,\n string | null | boolean | number | undefined\n>;\n\nexport function mergeHeaders(\n base: HeadersInit | CustomHeaders | undefined,\n overwrite?: HeadersInit | CustomHeaders,\n) {\n const baseHeaders = normalizeHeaders(base);\n const overwriteHeaders = normalizeHeaders(overwrite);\n\n overwriteHeaders.forEach((value, key) => {\n baseHeaders.set(key, value);\n });\n\n return baseHeaders;\n}\n\nexport function normalizeHeaders(\n headers: HeadersInit | CustomHeaders | undefined,\n) {\n // This might be custom header config containing null | boolean | number | undefined\n // By default Headers constructor will convert them to string but we don't want that\n // for nullish values.\n if (headers && !(headers instanceof Headers) && !Array.isArray(headers)) {\n return new Headers(\n Object.fromEntries(\n Object.entries(headers)\n .filter(([, v]) => v != null)\n .map(([k, v]) => [k, String(v)]),\n ),\n );\n }\n\n return new Headers(headers);\n}\n"],
5
+ "mappings": "AAKO,SAASA,EACdC,EACAC,EACA,CACA,IAAMC,EAAcC,EAAiBH,CAAI,EAGzC,OAFyBG,EAAiBF,CAAS,EAElC,QAAQ,CAACG,EAAOC,IAAQ,CACvCH,EAAY,IAAIG,EAAKD,CAAK,CAC5B,CAAC,EAEMF,CACT,CAEO,SAASC,EACdG,EACA,CAIA,OAAIA,GAAW,EAAEA,aAAmB,UAAY,CAAC,MAAM,QAAQA,CAAO,EAC7D,IAAI,QACT,OAAO,YACL,OAAO,QAAQA,CAAO,EACnB,OAAO,CAAC,CAAC,CAAEC,CAAC,IAAMA,GAAK,IAAI,EAC3B,IAAI,CAAC,CAACC,EAAGD,CAAC,IAAM,CAACC,EAAG,OAAOD,CAAC,CAAC,CAAC,CACnC,CACF,EAGK,IAAI,QAAQD,CAAO,CAC5B",
6
+ "names": ["mergeHeaders", "base", "overwrite", "baseHeaders", "normalizeHeaders", "value", "key", "headers", "v", "k"]
7
+ }
@@ -0,0 +1,2 @@
1
+ var p=[encodeURIComponent,encodeURIComponent],s=[encodeURIComponent,encodeURI];function u(t,n=","){let r=(e,o)=>{let c=t[o%t.length];return typeof e>"u"?"":typeof e=="object"?Array.isArray(e)?e.map(c).join(n):Object.entries(e).reduce((i,d)=>[...i,...d],[]).map(c).join(n):c(String(e))};return(e,...o)=>e.reduce((c,a,i)=>`${c}${a}${r(o[i],i)}`,"")}function f(t=","){return(n,r=p)=>Object.entries(n).filter(([,e])=>e!==void 0).map(([e,o])=>u(r,t)`${e}=${o}`).join("&")}function l(...t){return t.filter(Boolean).map((n,r)=>r===0?n:n.replace(/^\/+/,"")).map((n,r,e)=>r===e.length-1?n:n.replace(/\/+$/,"")).join("/")}export{p as a,s as b,u as c,f as d,l as e};
2
+ //# sourceMappingURL=chunk-AU3ZD6WL.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/util.ts"],
4
+ "sourcesContent": ["type Encoders = Array<(s: string) => string>;\n\n// Encode param names and values as URIComponent\nexport const encodeReserved = [encodeURIComponent, encodeURIComponent];\nexport const allowReserved = [encodeURIComponent, encodeURI];\n\n/**\n * Creates a tag-function to encode template strings with the given encoders.\n */\nexport function encode(encoders: Encoders, delimiter = \",\") {\n const q = (v: any, i: number) => {\n const encoder = encoders[i % encoders.length];\n if (typeof v === \"undefined\") {\n return \"\";\n }\n if (typeof v === \"object\") {\n if (Array.isArray(v)) {\n return v.map(encoder).join(delimiter);\n }\n const flat = Object.entries(v).reduce(\n (flat, entry) => [...flat, ...entry],\n [] as any,\n );\n return flat.map(encoder).join(delimiter);\n }\n\n return encoder(String(v));\n };\n\n return (strings: TemplateStringsArray, ...values: any[]) => {\n return strings.reduce((prev, s, i) => {\n return `${prev}${s}${q(values[i], i)}`;\n }, \"\");\n };\n}\n\n/**\n * Separate array values by the given delimiter.\n */\nexport function delimited(delimiter = \",\") {\n return (params: Record<string, any>, encoders = encodeReserved) =>\n Object.entries(params)\n .filter(([, value]) => value !== undefined)\n .map(([name, value]) => encode(encoders, delimiter)`${name}=${value}`)\n .join(\"&\");\n}\n\nexport function joinUrl(...parts: Array<string | undefined>) {\n return parts\n .filter(Boolean)\n .map((s, i) => (i === 0 ? s : s!.replace(/^\\/+/, \"\")))\n .map((s, i, a) => (i === a.length - 1 ? s : s!.replace(/\\/+$/, \"\")))\n .join(\"/\");\n}\n"],
5
+ "mappings": "AAGO,IAAMA,EAAiB,CAAC,mBAAoB,kBAAkB,EACxDC,EAAgB,CAAC,mBAAoB,SAAS,EAKpD,SAASC,EAAOC,EAAoBC,EAAY,IAAK,CAC1D,IAAMC,EAAI,CAACC,EAAQC,IAAc,CAC/B,IAAMC,EAAUL,EAASI,EAAIJ,EAAS,MAAM,EAC5C,OAAI,OAAOG,EAAM,IACR,GAEL,OAAOA,GAAM,SACX,MAAM,QAAQA,CAAC,EACVA,EAAE,IAAIE,CAAO,EAAE,KAAKJ,CAAS,EAEzB,OAAO,QAAQE,CAAC,EAAE,OAC7B,CAACG,EAAMC,IAAU,CAAC,GAAGD,EAAM,GAAGC,CAAK,EACnC,CAAC,CACH,EACY,IAAIF,CAAO,EAAE,KAAKJ,CAAS,EAGlCI,EAAQ,OAAOF,CAAC,CAAC,CAC1B,EAEA,MAAO,CAACK,KAAkCC,IACjCD,EAAQ,OAAO,CAACE,EAAMC,EAAG,IACvB,GAAGD,CAAI,GAAGC,CAAC,GAAGT,EAAEO,EAAO,CAAC,EAAG,CAAC,CAAC,GACnC,EAAE,CAET,CAKO,SAASG,EAAUX,EAAY,IAAK,CACzC,MAAO,CAACY,EAA6Bb,EAAWH,IAC9C,OAAO,QAAQgB,CAAM,EAClB,OAAO,CAAC,CAAC,CAAEC,CAAK,IAAMA,IAAU,MAAS,EACzC,IAAI,CAAC,CAACC,EAAMD,CAAK,IAAMf,EAAOC,EAAUC,CAAS,IAAIc,CAAI,IAAID,CAAK,EAAE,EACpE,KAAK,GAAG,CACf,CAEO,SAASE,KAAWC,EAAkC,CAC3D,OAAOA,EACJ,OAAO,OAAO,EACd,IAAI,CAACN,EAAGP,IAAOA,IAAM,EAAIO,EAAIA,EAAG,QAAQ,OAAQ,EAAE,CAAE,EACpD,IAAI,CAACA,EAAGP,EAAGc,IAAOd,IAAMc,EAAE,OAAS,EAAIP,EAAIA,EAAG,QAAQ,OAAQ,EAAE,CAAE,EAClE,KAAK,GAAG,CACb",
6
+ "names": ["encodeReserved", "allowReserved", "encode", "encoders", "delimiter", "q", "v", "i", "encoder", "flat", "entry", "strings", "values", "prev", "s", "delimited", "params", "value", "name", "joinUrl", "parts", "a"]
7
+ }
@@ -0,0 +1,2 @@
1
+ import{a as d,c,d as p}from"./chunk-AU3ZD6WL.mjs";function x(...e){let t=e.filter(Boolean).join("&");return t&&`?${t}`}function m(e,[t,o]=d){let n=c([s=>s,t]),r=c([s=>s,o]),i=(s,y="")=>Object.entries(s).filter(([,f])=>f!==void 0).map(([f,u])=>{let j=Array.isArray(s)?"":f,$=y?n`${y}[${j}]`:f;return typeof u=="object"?i(u,$):r`${$}=${u}`}).join("&");return i(e)}function a(e,t=d){let o=c(t);return Object.entries(e).filter(([,n])=>n!==void 0).map(([n,r])=>Array.isArray(r)?r.map(i=>o`${n}=${i}`).join("&"):typeof r=="object"?a(r,t):o`${n}=${r}`).join("&")}function q(e,t=d){let o=c(t);return Object.entries(e).filter(([,n])=>n!==void 0).map(([n,r])=>{let i=JSON.stringify(r);return o`${n}=${i}`}).join("&")}var b=p(),A=p("|"),O=p("%20");export{x as a,m as b,a as c,q as d,b as e,A as f,O as g};
2
+ //# sourceMappingURL=chunk-E3LXWSGM.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/query.ts"],
4
+ "sourcesContent": ["import { encode, delimited, encodeReserved } from \"./util\";\n\n/**\n * Join params using an ampersand and prepends a questionmark if not empty.\n */\nexport function query(...params: string[]) {\n const s = params.filter(Boolean).join(\"&\");\n return s && `?${s}`;\n}\n\n/**\n * Serializes nested objects according to the `deepObject` style specified in\n * https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.0.md#style-values\n */\nexport function deep(\n params: Record<string, any>,\n [k, v] = encodeReserved,\n): string {\n const qk = encode([(s) => s, k]);\n const qv = encode([(s) => s, v]);\n // don't add index to arrays\n // https://github.com/expressjs/body-parser/issues/289\n const visit = (obj: any, prefix = \"\"): string =>\n Object.entries(obj)\n .filter(([, v]) => v !== undefined)\n .map(([prop, v]) => {\n const index = Array.isArray(obj) ? \"\" : prop;\n const key = prefix ? qk`${prefix}[${index}]` : prop;\n if (typeof v === \"object\") {\n return visit(v, key);\n }\n return qv`${key}=${v}`;\n })\n .join(\"&\");\n\n return visit(params);\n}\n\n/**\n * Property values of type array or object generate separate parameters\n * for each value of the array, or key-value-pair of the map.\n * For other types of properties this property has no effect.\n * See https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.0.md#encoding-object\n */\nexport function explode(\n params: Record<string, any>,\n encoders = encodeReserved,\n): string {\n const q = encode(encoders);\n return Object.entries(params)\n .filter(([, value]) => value !== undefined)\n .map(([name, value]) => {\n if (Array.isArray(value)) {\n return value.map((v) => q`${name}=${v}`).join(\"&\");\n }\n if (typeof value === \"object\") {\n return explode(value, encoders);\n }\n return q`${name}=${value}`;\n })\n .join(\"&\");\n}\n\nexport function json(\n params: Record<string, any>,\n encoders = encodeReserved,\n): string {\n const q = encode(encoders);\n return Object.entries(params)\n .filter(([, value]) => value !== undefined)\n .map(([name, value]) => {\n const v = JSON.stringify(value);\n return q`${name}=${v}`;\n })\n .join(\"&\");\n}\n\nexport const form = delimited();\nexport const pipe = delimited(\"|\");\nexport const space = delimited(\"%20\");\n"],
5
+ "mappings": "kDAKO,SAASA,KAASC,EAAkB,CACzC,IAAMC,EAAID,EAAO,OAAO,OAAO,EAAE,KAAK,GAAG,EACzC,OAAOC,GAAK,IAAIA,CAAC,EACnB,CAMO,SAASC,EACdF,EACA,CAACG,EAAGC,CAAC,EAAIC,EACD,CACR,IAAMC,EAAKC,EAAO,CAAE,GAAM,EAAGJ,CAAC,CAAC,EACzBK,EAAKD,EAAO,CAAE,GAAM,EAAGH,CAAC,CAAC,EAGzBK,EAAQ,CAACC,EAAUC,EAAS,KAChC,OAAO,QAAQD,CAAG,EACf,OAAO,CAAC,CAAC,CAAEN,CAAC,IAAMA,IAAM,MAAS,EACjC,IAAI,CAAC,CAACQ,EAAMR,CAAC,IAAM,CAClB,IAAMS,EAAQ,MAAM,QAAQH,CAAG,EAAI,GAAKE,EAClCE,EAAMH,EAASL,IAAKK,CAAM,IAAIE,CAAK,IAAMD,EAC/C,OAAI,OAAOR,GAAM,SACRK,EAAML,EAAGU,CAAG,EAEdN,IAAKM,CAAG,IAAIV,CAAC,EACtB,CAAC,EACA,KAAK,GAAG,EAEb,OAAOK,EAAMT,CAAM,CACrB,CAQO,SAASe,EACdf,EACAgB,EAAWX,EACH,CACR,IAAMY,EAAIV,EAAOS,CAAQ,EACzB,OAAO,OAAO,QAAQhB,CAAM,EACzB,OAAO,CAAC,CAAC,CAAEkB,CAAK,IAAMA,IAAU,MAAS,EACzC,IAAI,CAAC,CAACC,EAAMD,CAAK,IACZ,MAAM,QAAQA,CAAK,EACdA,EAAM,IAAKd,GAAMa,IAAIE,CAAI,IAAIf,CAAC,EAAE,EAAE,KAAK,GAAG,EAE/C,OAAOc,GAAU,SACZH,EAAQG,EAAOF,CAAQ,EAEzBC,IAAIE,CAAI,IAAID,CAAK,EACzB,EACA,KAAK,GAAG,CACb,CAEO,SAASE,EACdpB,EACAgB,EAAWX,EACH,CACR,IAAMY,EAAIV,EAAOS,CAAQ,EACzB,OAAO,OAAO,QAAQhB,CAAM,EACzB,OAAO,CAAC,CAAC,CAAEkB,CAAK,IAAMA,IAAU,MAAS,EACzC,IAAI,CAAC,CAACC,EAAMD,CAAK,IAAM,CACtB,IAAMd,EAAI,KAAK,UAAUc,CAAK,EAC9B,OAAOD,IAAIE,CAAI,IAAIf,CAAC,EACtB,CAAC,EACA,KAAK,GAAG,CACb,CAEO,IAAMiB,EAAOC,EAAU,EACjBC,EAAOD,EAAU,GAAG,EACpBE,EAAQF,EAAU,KAAK",
6
+ "names": ["query", "params", "s", "deep", "k", "v", "encodeReserved", "qk", "encode", "qv", "visit", "obj", "prefix", "prop", "index", "key", "explode", "encoders", "q", "value", "name", "json", "form", "delimited", "pipe", "space"]
7
+ }
@@ -0,0 +1,2 @@
1
+ import{e as R}from"./chunk-E3LXWSGM.mjs";import{e as x}from"./chunk-AU3ZD6WL.mjs";import{a as y,b as h}from"./chunk-6C7A2H7M.mjs";import{a as f}from"./chunk-T7KECS5U.mjs";async function H(a,s){let{status:o,data:p,headers:d}=await a,t=s[o];if(t)return t(p);if(s.default)return s.default(o,p);throw new T(o,p,d)}var l=[200,201,202,204];async function m(a){let s=await a;if(l.some(o=>o==s.status))return s.data;throw new T(s.status,s.data,s.headers)}function A(a){return(...s)=>m(a(...s))}function g(a){let s={};return Object.entries(a).forEach(([o,p])=>{s[o]=typeof p=="function"?A(p):p}),s}var T=class extends Error{constructor(o,p,d){super(`Error: ${o}`);f(this,"status");f(this,"data");f(this,"headers");this.status=o,this.data=p,this.headers=d}};function P(a={}){async function s(t,n){let e=await d(t,n),r;try{r=await e.text()}catch{}return{status:e.status,headers:e.headers,contentType:e.headers.get("content-type"),data:r}}async function o(t,n={}){let{status:e,headers:r,contentType:c,data:i}=await s(t,{...n,headers:y({Accept:"application/json"},n.headers)});return(c?c.includes("json"):!1)?{status:e,headers:r,data:i?JSON.parse(i):null}:{status:e,headers:r,data:i}}async function p(t,n={}){let e=await d(t,n),r;try{r=await e.blob()}catch{}return{status:e.status,headers:e.headers,data:r}}async function d(t,n={}){let{baseUrl:e,fetch:r,...c}={...a,...n,headers:y(a.headers,n.headers)},i=x(e,t);return await(r||fetch)(i,c)}return{ok:m,fetchText:s,fetchJson:o,fetchBlob:p,mergeHeaders:y,json({body:t,headers:n,...e}){return{...e,...t!=null&&{body:JSON.stringify(t)},headers:y({"Content-Type":"application/json"},n)}},form({body:t,headers:n,...e}){return{...e,...t!=null&&{body:R(t)},headers:y({"Content-Type":"application/x-www-form-urlencoded"},n)}},multipart({body:t,headers:n,...e}){if(t==null)return{...e,body:t,headers:h(n)};let r=new(a.formDataConstructor||e.formDataConstructor||FormData),c=(i,u)=>{typeof u=="string"||u instanceof Blob?r.append(i,u):r.append(i,new Blob([JSON.stringify(u)],{type:"application/json"}))};return Object.entries(t).forEach(([i,u])=>{Array.isArray(u)?u.forEach(O=>c(i,O)):c(i,u)}),{...e,body:r,headers:h(n)}}}}export{P as a,H as b,l as c,m as d,A as e,g as f,T as g};
2
+ //# sourceMappingURL=chunk-LUOVPBCG.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/index.ts", "../src/runtime.ts"],
4
+ "sourcesContent": ["import type { ApiResponse, WithHeaders } from \"./runtime\";\n\nexport * from \"./runtime\";\n\n/**\n * Type to access a response's data property for a given status.\n */\nexport type DataType<T extends ApiResponse, S extends number> = T extends {\n status: S;\n}\n ? T[\"data\"]\n : never;\n\n/**\n * Object with methods to handle possible status codes of an ApiResponse.\n */\nexport type ResponseHandler<T extends ApiResponse> = {\n [P in T[\"status\"]]?: (res: DataType<T, P>) => any;\n} & {\n default?: (status: number, data: any) => any;\n};\n\nexport type FunctionReturnType<T> = T extends (...args: any[]) => any\n ? ReturnType<T>\n : never;\n\n/**\n * Utility function to handle different status codes.\n *\n * Example:\n *\n * const userId = await handle(api.register({ email, password }), {\n * 200: (user: User) => user.id,\n * 400: (err: string) => console.log(err),\n * })\n **/\nexport async function handle<\n T extends WithHeaders<ApiResponse>,\n H extends ResponseHandler<T>,\n>(promise: Promise<T>, handler: H): Promise<FunctionReturnType<H[keyof H]>> {\n const { status, data, headers } = await promise;\n const statusHandler = (handler as any)[status];\n if (statusHandler) return statusHandler(data);\n if (handler.default) return handler.default(status, data);\n throw new HttpError(status, data, headers);\n}\n\nexport const SUCCESS_CODES = [200, 201, 202, 204] as const;\nexport type SuccessCodes = (typeof SUCCESS_CODES)[number];\n\nexport type SuccessResponse<T extends ApiResponse> = DataType<T, SuccessCodes>;\n\n/**\n * Utility function to directly return any successful response\n * and throw a HttpError otherwise.\n *\n * Example:\n *\n * try {\n * const userId = await ok(api.register({ email, password }));\n * }\n * catch (err) {\n * console.log(err.status)\n * }\n */\nexport async function ok<T extends WithHeaders<ApiResponse>>(\n promise: Promise<T>,\n): Promise<SuccessResponse<T>> {\n const res = await promise;\n if (SUCCESS_CODES.some((s) => s == res.status)) return res.data;\n throw new HttpError(res.status, res.data, res.headers);\n}\n\nexport type Args<T> = T extends (...args: infer U) => any ? U : any;\nexport type ApiFunction = (...args: any[]) => Promise<WithHeaders<ApiResponse>>;\nexport type AsyncReturnType<T> = T extends (...args: any[]) => Promise<infer V>\n ? V\n : never;\n\nexport type OkResponse<T extends ApiFunction> = SuccessResponse<\n AsyncReturnType<T>\n>;\n\nexport type Okify<T extends ApiFunction> = (\n ...args: Args<T>\n) => Promise<OkResponse<T>>;\n\n/**\n * Utility function to wrap an API function with `ok(...)`.\n */\nexport function okify<T extends ApiFunction>(fn: T): Okify<T> {\n return (...args: Args<T>) => ok(fn(...args));\n}\n\ntype OptimisticApi<T> = {\n [K in keyof T]: T[K] extends ApiFunction ? Okify<T[K]> : T[K];\n};\n\n/**\n * Utility to `okify` each function of an API.\n */\nexport function optimistic<T extends Record<string, ApiFunction | unknown>>(\n api: T,\n): OptimisticApi<T> {\n const okApi: any = {};\n Object.entries(api).forEach(([key, value]) => {\n okApi[key] = typeof value === \"function\" ? okify(value as any) : value;\n });\n return okApi;\n}\n\nexport class HttpError extends Error {\n status: number;\n data?: any;\n headers: Headers;\n\n constructor(status: number, data: any, headers: Headers) {\n super(`Error: ${status}`);\n this.status = status;\n this.data = data;\n this.headers = headers;\n }\n}\n", "import * as qs from \"./query\";\nimport { joinUrl } from \"./util\";\nimport { ok } from \"./index\";\nimport { CustomHeaders, mergeHeaders, normalizeHeaders } from \"./headers\";\n\nexport { type CustomHeaders };\n\nexport type RequestOpts = {\n baseUrl?: string;\n fetch?: typeof fetch;\n formDataConstructor?: new () => FormData;\n headers?: HeadersInit | CustomHeaders;\n} & Omit<RequestInit, \"body\" | \"headers\">;\n\nexport type Defaults<Headers extends RequestOpts[\"headers\"] = CustomHeaders> =\n Omit<RequestOpts, \"headers\" | \"baseUrl\"> & {\n baseUrl: string;\n headers: Headers;\n };\n\ntype FetchRequestOpts = RequestOpts & {\n body?: string | FormData | Blob;\n};\n\ntype JsonRequestOpts = RequestOpts & {\n body?: any;\n};\n\ntype FormRequestOpts = RequestOpts & {\n body?: Record<string, any>;\n};\n\nexport type ApiResponse = { status: number; data?: any };\n\nexport type WithHeaders<T extends ApiResponse> = T & { headers: Headers };\n\ntype MultipartRequestOpts = RequestOpts & {\n body?: Record<string, unknown>;\n};\n\nexport function runtime(defaults: RequestOpts = {}) {\n async function fetchText(url: string, req?: FetchRequestOpts) {\n const res = await doFetch(url, req);\n let data;\n try {\n data = await res.text();\n } catch (err) {}\n\n return {\n status: res.status,\n headers: res.headers,\n contentType: res.headers.get(\"content-type\"),\n data,\n };\n }\n\n async function fetchJson<T extends ApiResponse>(\n url: string,\n req: FetchRequestOpts = {},\n ) {\n const { status, headers, contentType, data } = await fetchText(url, {\n ...req,\n headers: mergeHeaders(\n {\n Accept: \"application/json\",\n },\n req.headers,\n ),\n });\n\n const isJson = contentType ? contentType.includes(\"json\") : false;\n\n if (isJson) {\n return {\n status,\n headers,\n data: data ? JSON.parse(data) : null,\n } as WithHeaders<T>;\n }\n\n return { status, headers, data } as WithHeaders<T>;\n }\n\n async function fetchBlob<T extends ApiResponse>(\n url: string,\n req: FetchRequestOpts = {},\n ) {\n const res = await doFetch(url, req);\n let data;\n try {\n data = await res.blob();\n } catch (err) {}\n return { status: res.status, headers: res.headers, data } as WithHeaders<T>;\n }\n\n async function doFetch(url: string, req: FetchRequestOpts = {}) {\n const {\n baseUrl,\n fetch: customFetch,\n ...init\n } = {\n ...defaults,\n ...req,\n headers: mergeHeaders(defaults.headers, req.headers),\n };\n const href = joinUrl(baseUrl, url);\n const res = await (customFetch || fetch)(href, init);\n return res;\n }\n\n return {\n ok,\n fetchText,\n fetchJson,\n fetchBlob,\n mergeHeaders,\n\n json({ body, headers, ...req }: JsonRequestOpts) {\n return {\n ...req,\n ...(body != null && { body: JSON.stringify(body) }),\n headers: mergeHeaders(\n {\n \"Content-Type\": \"application/json\",\n },\n headers,\n ),\n };\n },\n\n form({ body, headers, ...req }: FormRequestOpts) {\n return {\n ...req,\n ...(body != null && { body: qs.form(body) }),\n headers: mergeHeaders(\n {\n \"Content-Type\": \"application/x-www-form-urlencoded\",\n },\n headers,\n ),\n };\n },\n\n multipart({ body, headers, ...req }: MultipartRequestOpts) {\n if (body == null)\n return { ...req, body, headers: normalizeHeaders(headers) };\n\n const data = new (defaults.formDataConstructor ||\n req.formDataConstructor ||\n FormData)();\n\n const append = (name: string, value: unknown) => {\n if (typeof value === \"string\" || value instanceof Blob) {\n data.append(name, value);\n } else {\n data.append(\n name,\n new Blob([JSON.stringify(value)], { type: \"application/json\" }),\n );\n }\n };\n\n Object.entries(body).forEach(([name, value]) => {\n if (Array.isArray(value)) {\n value.forEach((v) => append(name, v));\n } else {\n append(name, value);\n }\n });\n\n return {\n ...req,\n body: data,\n headers: normalizeHeaders(headers),\n };\n },\n };\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["handle", "promise", "handler", "status", "data", "headers", "statusHandler", "HttpError", "SUCCESS_CODES", "ok", "res", "s", "okify", "fn", "args", "optimistic", "api", "okApi", "key", "value", "__publicField", "runtime", "defaults", "fetchText", "url", "req", "res", "doFetch", "data", "fetchJson", "status", "headers", "contentType", "mergeHeaders", "fetchBlob", "baseUrl", "customFetch", "init", "href", "joinUrl", "ok", "body", "form", "normalizeHeaders", "append", "name", "value", "v"]
7
+ }
@@ -0,0 +1,2 @@
1
+ var d=Object.defineProperty;var e=(b,a,c)=>a in b?d(b,a,{enumerable:!0,configurable:!0,writable:!0,value:c}):b[a]=c;var f=(b,a,c)=>(e(b,typeof a!="symbol"?a+"":a,c),c);export{f as a};
2
+ //# sourceMappingURL=chunk-T7KECS5U.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": [],
4
+ "sourcesContent": [],
5
+ "mappings": "",
6
+ "names": []
7
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";var i=Object.defineProperty;var d=Object.getOwnPropertyDescriptor;var u=Object.getOwnPropertyNames;var H=Object.prototype.hasOwnProperty;var f=(e,r)=>{for(var n in r)i(e,n,{get:r[n],enumerable:!0})},c=(e,r,n,s)=>{if(r&&typeof r=="object"||typeof r=="function")for(let t of u(r))!H.call(e,t)&&t!==n&&i(e,t,{get:()=>r[t],enumerable:!(s=d(r,t))||s.enumerable});return e};var m=e=>c(i({},"__esModule",{value:!0}),e);var b={};f(b,{mergeHeaders:()=>l,normalizeHeaders:()=>o});module.exports=m(b);function l(e,r){const n=o(e);return o(r).forEach((t,a)=>{n.set(a,t)}),n}function o(e){return e&&!(e instanceof Headers)&&!Array.isArray(e)?new Headers(Object.fromEntries(Object.entries(e).filter(([,r])=>r!=null).map(([r,n])=>[r,String(n)]))):new Headers(e)}
2
+ //# sourceMappingURL=headers.cjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/headers.ts"],
4
+ "sourcesContent": ["export type CustomHeaders = Record<\n string,\n string | null | boolean | number | undefined\n>;\n\nexport function mergeHeaders(\n base: HeadersInit | CustomHeaders | undefined,\n overwrite?: HeadersInit | CustomHeaders,\n) {\n const baseHeaders = normalizeHeaders(base);\n const overwriteHeaders = normalizeHeaders(overwrite);\n\n overwriteHeaders.forEach((value, key) => {\n baseHeaders.set(key, value);\n });\n\n return baseHeaders;\n}\n\nexport function normalizeHeaders(\n headers: HeadersInit | CustomHeaders | undefined,\n) {\n // This might be custom header config containing null | boolean | number | undefined\n // By default Headers constructor will convert them to string but we don't want that\n // for nullish values.\n if (headers && !(headers instanceof Headers) && !Array.isArray(headers)) {\n return new Headers(\n Object.fromEntries(\n Object.entries(headers)\n .filter(([, v]) => v != null)\n .map(([k, v]) => [k, String(v)]),\n ),\n );\n }\n\n return new Headers(headers);\n}\n"],
5
+ "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,kBAAAE,EAAA,qBAAAC,IAAA,eAAAC,EAAAJ,GAKO,SAASE,EACdG,EACAC,EACA,CACA,MAAMC,EAAcJ,EAAiBE,CAAI,EAGzC,OAFyBF,EAAiBG,CAAS,EAElC,QAAQ,CAACE,EAAOC,IAAQ,CACvCF,EAAY,IAAIE,EAAKD,CAAK,CAC5B,CAAC,EAEMD,CACT,CAEO,SAASJ,EACdO,EACA,CAIA,OAAIA,GAAW,EAAEA,aAAmB,UAAY,CAAC,MAAM,QAAQA,CAAO,EAC7D,IAAI,QACT,OAAO,YACL,OAAO,QAAQA,CAAO,EACnB,OAAO,CAAC,CAAC,CAAEC,CAAC,IAAMA,GAAK,IAAI,EAC3B,IAAI,CAAC,CAACC,EAAGD,CAAC,IAAM,CAACC,EAAG,OAAOD,CAAC,CAAC,CAAC,CACnC,CACF,EAGK,IAAI,QAAQD,CAAO,CAC5B",
6
+ "names": ["headers_exports", "__export", "mergeHeaders", "normalizeHeaders", "__toCommonJS", "base", "overwrite", "baseHeaders", "value", "key", "headers", "v", "k"]
7
+ }
@@ -0,0 +1,3 @@
1
+ export type CustomHeaders = Record<string, string | null | boolean | number | undefined>;
2
+ export declare function mergeHeaders(base: HeadersInit | CustomHeaders | undefined, overwrite?: HeadersInit | CustomHeaders): Headers;
3
+ export declare function normalizeHeaders(headers: HeadersInit | CustomHeaders | undefined): Headers;
@@ -0,0 +1,2 @@
1
+ import{a,b}from"./chunk-6C7A2H7M.mjs";import"./chunk-T7KECS5U.mjs";export{a as mergeHeaders,b as normalizeHeaders};
2
+ //# sourceMappingURL=headers.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": [],
4
+ "sourcesContent": [],
5
+ "mappings": "",
6
+ "names": []
7
+ }
package/dist/index.cjs ADDED
@@ -0,0 +1,2 @@
1
+ "use strict";var i=Object.defineProperty;var H=Object.getOwnPropertyDescriptor;var h=Object.getOwnPropertyNames;var k=Object.prototype.hasOwnProperty;var O=(s,e,t)=>e in s?i(s,e,{enumerable:!0,configurable:!0,writable:!0,value:t}):s[e]=t;var g=(s,e)=>{for(var t in e)i(s,t,{get:e[t],enumerable:!0})},d=(s,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of h(e))!k.call(s,r)&&r!==t&&i(s,r,{get:()=>e[r],enumerable:!(n=H(e,r))||n.enumerable});return s},u=(s,e,t)=>(d(s,e,"default"),t&&d(t,e,"default"));var P=s=>d(i({},"__esModule",{value:!0}),s);var y=(s,e,t)=>(O(s,typeof e!="symbol"?e+"":e,t),t);var x=(s,e,t)=>new Promise((n,r)=>{var a=o=>{try{T(t.next(o))}catch(c){r(c)}},S=o=>{try{T(t.throw(o))}catch(c){r(c)}},T=o=>o.done?n(o.value):Promise.resolve(o.value).then(a,S);T((t=t.apply(s,e)).next())});var p={};g(p,{HttpError:()=>f,SUCCESS_CODES:()=>A,handle:()=>C,ok:()=>m,okify:()=>R,optimistic:()=>E});module.exports=P(p);u(p,require("./runtime"),module.exports);function C(s,e){return x(this,null,function*(){const{status:t,data:n,headers:r}=yield s,a=e[t];if(a)return a(n);if(e.default)return e.default(t,n);throw new f(t,n,r)})}const A=[200,201,202,204];function m(s){return x(this,null,function*(){const e=yield s;if(A.some(t=>t==e.status))return e.data;throw new f(e.status,e.data,e.headers)})}function R(s){return(...e)=>m(s(...e))}function E(s){const e={};return Object.entries(s).forEach(([t,n])=>{e[t]=typeof n=="function"?R(n):n}),e}class f extends Error{constructor(t,n,r){super(`Error: ${t}`);y(this,"status");y(this,"data");y(this,"headers");this.status=t,this.data=n,this.headers=r}}
2
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/index.ts"],
4
+ "sourcesContent": ["import type { ApiResponse, WithHeaders } from \"./runtime\";\n\nexport * from \"./runtime\";\n\n/**\n * Type to access a response's data property for a given status.\n */\nexport type DataType<T extends ApiResponse, S extends number> = T extends {\n status: S;\n}\n ? T[\"data\"]\n : never;\n\n/**\n * Object with methods to handle possible status codes of an ApiResponse.\n */\nexport type ResponseHandler<T extends ApiResponse> = {\n [P in T[\"status\"]]?: (res: DataType<T, P>) => any;\n} & {\n default?: (status: number, data: any) => any;\n};\n\nexport type FunctionReturnType<T> = T extends (...args: any[]) => any\n ? ReturnType<T>\n : never;\n\n/**\n * Utility function to handle different status codes.\n *\n * Example:\n *\n * const userId = await handle(api.register({ email, password }), {\n * 200: (user: User) => user.id,\n * 400: (err: string) => console.log(err),\n * })\n **/\nexport async function handle<\n T extends WithHeaders<ApiResponse>,\n H extends ResponseHandler<T>,\n>(promise: Promise<T>, handler: H): Promise<FunctionReturnType<H[keyof H]>> {\n const { status, data, headers } = await promise;\n const statusHandler = (handler as any)[status];\n if (statusHandler) return statusHandler(data);\n if (handler.default) return handler.default(status, data);\n throw new HttpError(status, data, headers);\n}\n\nexport const SUCCESS_CODES = [200, 201, 202, 204] as const;\nexport type SuccessCodes = (typeof SUCCESS_CODES)[number];\n\nexport type SuccessResponse<T extends ApiResponse> = DataType<T, SuccessCodes>;\n\n/**\n * Utility function to directly return any successful response\n * and throw a HttpError otherwise.\n *\n * Example:\n *\n * try {\n * const userId = await ok(api.register({ email, password }));\n * }\n * catch (err) {\n * console.log(err.status)\n * }\n */\nexport async function ok<T extends WithHeaders<ApiResponse>>(\n promise: Promise<T>,\n): Promise<SuccessResponse<T>> {\n const res = await promise;\n if (SUCCESS_CODES.some((s) => s == res.status)) return res.data;\n throw new HttpError(res.status, res.data, res.headers);\n}\n\nexport type Args<T> = T extends (...args: infer U) => any ? U : any;\nexport type ApiFunction = (...args: any[]) => Promise<WithHeaders<ApiResponse>>;\nexport type AsyncReturnType<T> = T extends (...args: any[]) => Promise<infer V>\n ? V\n : never;\n\nexport type OkResponse<T extends ApiFunction> = SuccessResponse<\n AsyncReturnType<T>\n>;\n\nexport type Okify<T extends ApiFunction> = (\n ...args: Args<T>\n) => Promise<OkResponse<T>>;\n\n/**\n * Utility function to wrap an API function with `ok(...)`.\n */\nexport function okify<T extends ApiFunction>(fn: T): Okify<T> {\n return (...args: Args<T>) => ok(fn(...args));\n}\n\ntype OptimisticApi<T> = {\n [K in keyof T]: T[K] extends ApiFunction ? Okify<T[K]> : T[K];\n};\n\n/**\n * Utility to `okify` each function of an API.\n */\nexport function optimistic<T extends Record<string, ApiFunction | unknown>>(\n api: T,\n): OptimisticApi<T> {\n const okApi: any = {};\n Object.entries(api).forEach(([key, value]) => {\n okApi[key] = typeof value === \"function\" ? okify(value as any) : value;\n });\n return okApi;\n}\n\nexport class HttpError extends Error {\n status: number;\n data?: any;\n headers: Headers;\n\n constructor(status: number, data: any, headers: Headers) {\n super(`Error: ${status}`);\n this.status = status;\n this.data = data;\n this.headers = headers;\n }\n}\n"],
5
+ "mappings": "ozBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,eAAAE,EAAA,kBAAAC,EAAA,WAAAC,EAAA,OAAAC,EAAA,UAAAC,EAAA,eAAAC,IAAA,eAAAC,EAAAR,GAEAS,EAAAC,EAAc,qBAFd,gBAoCA,SAAsBC,EAGpBC,EAAqBC,EAAqD,QAAAC,EAAA,sBAC1E,KAAM,CAAE,OAAAC,EAAQ,KAAAC,EAAM,QAAAC,CAAQ,EAAI,MAAML,EAClCM,EAAiBL,EAAgBE,CAAM,EAC7C,GAAIG,EAAe,OAAOA,EAAcF,CAAI,EAC5C,GAAIH,EAAQ,QAAS,OAAOA,EAAQ,QAAQE,EAAQC,CAAI,EACxD,MAAM,IAAIG,EAAUJ,EAAQC,EAAMC,CAAO,CAC3C,GAEO,MAAMG,EAAgB,CAAC,IAAK,IAAK,IAAK,GAAG,EAkBhD,SAAsBC,EACpBT,EAC6B,QAAAE,EAAA,sBAC7B,MAAMQ,EAAM,MAAMV,EAClB,GAAIQ,EAAc,KAAMG,GAAMA,GAAKD,EAAI,MAAM,EAAG,OAAOA,EAAI,KAC3D,MAAM,IAAIH,EAAUG,EAAI,OAAQA,EAAI,KAAMA,EAAI,OAAO,CACvD,GAmBO,SAASE,EAA6BC,EAAiB,CAC5D,MAAO,IAAIC,IAAkBL,EAAGI,EAAG,GAAGC,CAAI,CAAC,CAC7C,CASO,SAASC,EACdC,EACkB,CAClB,MAAMC,EAAa,CAAC,EACpB,cAAO,QAAQD,CAAG,EAAE,QAAQ,CAAC,CAACE,EAAKC,CAAK,IAAM,CAC5CF,EAAMC,CAAG,EAAI,OAAOC,GAAU,WAAaP,EAAMO,CAAY,EAAIA,CACnE,CAAC,EACMF,CACT,CAEO,MAAMV,UAAkB,KAAM,CAKnC,YAAYJ,EAAgBC,EAAWC,EAAkB,CACvD,MAAM,UAAUF,CAAM,EAAE,EAL1BiB,EAAA,eACAA,EAAA,aACAA,EAAA,gBAIE,KAAK,OAASjB,EACd,KAAK,KAAOC,EACZ,KAAK,QAAUC,CACjB,CACF",
6
+ "names": ["src_exports", "__export", "HttpError", "SUCCESS_CODES", "handle", "ok", "okify", "optimistic", "__toCommonJS", "__reExport", "src_exports", "handle", "promise", "handler", "__async", "status", "data", "headers", "statusHandler", "HttpError", "SUCCESS_CODES", "ok", "res", "s", "okify", "fn", "args", "optimistic", "api", "okApi", "key", "value", "__publicField"]
7
+ }
@@ -0,0 +1,67 @@
1
+ import type { ApiResponse, WithHeaders } from "./runtime";
2
+ export * from "./runtime";
3
+ /**
4
+ * Type to access a response's data property for a given status.
5
+ */
6
+ export type DataType<T extends ApiResponse, S extends number> = T extends {
7
+ status: S;
8
+ } ? T["data"] : never;
9
+ /**
10
+ * Object with methods to handle possible status codes of an ApiResponse.
11
+ */
12
+ export type ResponseHandler<T extends ApiResponse> = {
13
+ [P in T["status"]]?: (res: DataType<T, P>) => any;
14
+ } & {
15
+ default?: (status: number, data: any) => any;
16
+ };
17
+ export type FunctionReturnType<T> = T extends (...args: any[]) => any ? ReturnType<T> : never;
18
+ /**
19
+ * Utility function to handle different status codes.
20
+ *
21
+ * Example:
22
+ *
23
+ * const userId = await handle(api.register({ email, password }), {
24
+ * 200: (user: User) => user.id,
25
+ * 400: (err: string) => console.log(err),
26
+ * })
27
+ **/
28
+ export declare function handle<T extends WithHeaders<ApiResponse>, H extends ResponseHandler<T>>(promise: Promise<T>, handler: H): Promise<FunctionReturnType<H[keyof H]>>;
29
+ export declare const SUCCESS_CODES: readonly [200, 201, 202, 204];
30
+ export type SuccessCodes = (typeof SUCCESS_CODES)[number];
31
+ export type SuccessResponse<T extends ApiResponse> = DataType<T, SuccessCodes>;
32
+ /**
33
+ * Utility function to directly return any successful response
34
+ * and throw a HttpError otherwise.
35
+ *
36
+ * Example:
37
+ *
38
+ * try {
39
+ * const userId = await ok(api.register({ email, password }));
40
+ * }
41
+ * catch (err) {
42
+ * console.log(err.status)
43
+ * }
44
+ */
45
+ export declare function ok<T extends WithHeaders<ApiResponse>>(promise: Promise<T>): Promise<SuccessResponse<T>>;
46
+ export type Args<T> = T extends (...args: infer U) => any ? U : any;
47
+ export type ApiFunction = (...args: any[]) => Promise<WithHeaders<ApiResponse>>;
48
+ export type AsyncReturnType<T> = T extends (...args: any[]) => Promise<infer V> ? V : never;
49
+ export type OkResponse<T extends ApiFunction> = SuccessResponse<AsyncReturnType<T>>;
50
+ export type Okify<T extends ApiFunction> = (...args: Args<T>) => Promise<OkResponse<T>>;
51
+ /**
52
+ * Utility function to wrap an API function with `ok(...)`.
53
+ */
54
+ export declare function okify<T extends ApiFunction>(fn: T): Okify<T>;
55
+ type OptimisticApi<T> = {
56
+ [K in keyof T]: T[K] extends ApiFunction ? Okify<T[K]> : T[K];
57
+ };
58
+ /**
59
+ * Utility to `okify` each function of an API.
60
+ */
61
+ export declare function optimistic<T extends Record<string, ApiFunction | unknown>>(api: T): OptimisticApi<T>;
62
+ export declare class HttpError extends Error {
63
+ status: number;
64
+ data?: any;
65
+ headers: Headers;
66
+ constructor(status: number, data: any, headers: Headers);
67
+ }
package/dist/index.mjs ADDED
@@ -0,0 +1,2 @@
1
+ import{a,b,c,d,e,f,g}from"./chunk-LUOVPBCG.mjs";import"./chunk-E3LXWSGM.mjs";import"./chunk-AU3ZD6WL.mjs";import"./chunk-6C7A2H7M.mjs";import"./chunk-T7KECS5U.mjs";export{g as HttpError,c as SUCCESS_CODES,b as handle,d as ok,e as okify,f as optimistic,a as runtime};
2
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": [],
4
+ "sourcesContent": [],
5
+ "mappings": "",
6
+ "names": []
7
+ }
@@ -0,0 +1 @@
1
+ export {};
package/dist/query.cjs ADDED
@@ -0,0 +1,2 @@
1
+ "use strict";var p=Object.defineProperty;var a=Object.getOwnPropertyDescriptor;var g=Object.getOwnPropertyNames;var x=Object.prototype.hasOwnProperty;var m=(t,n)=>{for(var i in n)p(t,i,{get:n[i],enumerable:!0})},q=(t,n,i,e)=>{if(n&&typeof n=="object"||typeof n=="function")for(let r of g(n))!x.call(t,r)&&r!==i&&p(t,r,{get:()=>n[r],enumerable:!(e=a(n,r))||e.enumerable});return t};var b=t=>q(p({},"__esModule",{value:!0}),t);var J={};m(J,{deep:()=>O,explode:()=>$,form:()=>l,json:()=>R,pipe:()=>k,query:()=>A,space:()=>B});module.exports=b(J);var o=require("./util");function A(...t){const n=t.filter(Boolean).join("&");return n&&`?${n}`}function O(t,[n,i]=o.encodeReserved){const e=(0,o.encode)([c=>c,n]),r=(0,o.encode)([c=>c,i]),s=(c,u="")=>Object.entries(c).filter(([,f])=>f!==void 0).map(([f,d])=>{const j=Array.isArray(c)?"":f,y=u?e`${u}[${j}]`:f;return typeof d=="object"?s(d,y):r`${y}=${d}`}).join("&");return s(t)}function $(t,n=o.encodeReserved){const i=(0,o.encode)(n);return Object.entries(t).filter(([,e])=>e!==void 0).map(([e,r])=>Array.isArray(r)?r.map(s=>i`${e}=${s}`).join("&"):typeof r=="object"?$(r,n):i`${e}=${r}`).join("&")}function R(t,n=o.encodeReserved){const i=(0,o.encode)(n);return Object.entries(t).filter(([,e])=>e!==void 0).map(([e,r])=>{const s=JSON.stringify(r);return i`${e}=${s}`}).join("&")}const l=(0,o.delimited)(),k=(0,o.delimited)("|"),B=(0,o.delimited)("%20");
2
+ //# sourceMappingURL=query.cjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/query.ts"],
4
+ "sourcesContent": ["import { encode, delimited, encodeReserved } from \"./util\";\n\n/**\n * Join params using an ampersand and prepends a questionmark if not empty.\n */\nexport function query(...params: string[]) {\n const s = params.filter(Boolean).join(\"&\");\n return s && `?${s}`;\n}\n\n/**\n * Serializes nested objects according to the `deepObject` style specified in\n * https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.0.md#style-values\n */\nexport function deep(\n params: Record<string, any>,\n [k, v] = encodeReserved,\n): string {\n const qk = encode([(s) => s, k]);\n const qv = encode([(s) => s, v]);\n // don't add index to arrays\n // https://github.com/expressjs/body-parser/issues/289\n const visit = (obj: any, prefix = \"\"): string =>\n Object.entries(obj)\n .filter(([, v]) => v !== undefined)\n .map(([prop, v]) => {\n const index = Array.isArray(obj) ? \"\" : prop;\n const key = prefix ? qk`${prefix}[${index}]` : prop;\n if (typeof v === \"object\") {\n return visit(v, key);\n }\n return qv`${key}=${v}`;\n })\n .join(\"&\");\n\n return visit(params);\n}\n\n/**\n * Property values of type array or object generate separate parameters\n * for each value of the array, or key-value-pair of the map.\n * For other types of properties this property has no effect.\n * See https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.0.md#encoding-object\n */\nexport function explode(\n params: Record<string, any>,\n encoders = encodeReserved,\n): string {\n const q = encode(encoders);\n return Object.entries(params)\n .filter(([, value]) => value !== undefined)\n .map(([name, value]) => {\n if (Array.isArray(value)) {\n return value.map((v) => q`${name}=${v}`).join(\"&\");\n }\n if (typeof value === \"object\") {\n return explode(value, encoders);\n }\n return q`${name}=${value}`;\n })\n .join(\"&\");\n}\n\nexport function json(\n params: Record<string, any>,\n encoders = encodeReserved,\n): string {\n const q = encode(encoders);\n return Object.entries(params)\n .filter(([, value]) => value !== undefined)\n .map(([name, value]) => {\n const v = JSON.stringify(value);\n return q`${name}=${v}`;\n })\n .join(\"&\");\n}\n\nexport const form = delimited();\nexport const pipe = delimited(\"|\");\nexport const space = delimited(\"%20\");\n"],
5
+ "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,UAAAE,EAAA,YAAAC,EAAA,SAAAC,EAAA,SAAAC,EAAA,SAAAC,EAAA,UAAAC,EAAA,UAAAC,IAAA,eAAAC,EAAAT,GAAA,IAAAU,EAAkD,kBAK3C,SAASH,KAASI,EAAkB,CACzC,MAAMC,EAAID,EAAO,OAAO,OAAO,EAAE,KAAK,GAAG,EACzC,OAAOC,GAAK,IAAIA,CAAC,EACnB,CAMO,SAASV,EACdS,EACA,CAACE,EAAGC,CAAC,EAAI,iBACD,CACR,MAAMC,KAAK,UAAO,CAAEH,GAAMA,EAAGC,CAAC,CAAC,EACzBG,KAAK,UAAO,CAAEJ,GAAMA,EAAGE,CAAC,CAAC,EAGzBG,EAAQ,CAACC,EAAUC,EAAS,KAChC,OAAO,QAAQD,CAAG,EACf,OAAO,CAAC,CAAC,CAAEJ,CAAC,IAAMA,IAAM,MAAS,EACjC,IAAI,CAAC,CAACM,EAAMN,CAAC,IAAM,CAClB,MAAMO,EAAQ,MAAM,QAAQH,CAAG,EAAI,GAAKE,EAClCE,EAAMH,EAASJ,IAAKI,CAAM,IAAIE,CAAK,IAAMD,EAC/C,OAAI,OAAON,GAAM,SACRG,EAAMH,EAAGQ,CAAG,EAEdN,IAAKM,CAAG,IAAIR,CAAC,EACtB,CAAC,EACA,KAAK,GAAG,EAEb,OAAOG,EAAMN,CAAM,CACrB,CAQO,SAASR,EACdQ,EACAY,EAAW,iBACH,CACR,MAAMC,KAAI,UAAOD,CAAQ,EACzB,OAAO,OAAO,QAAQZ,CAAM,EACzB,OAAO,CAAC,CAAC,CAAEc,CAAK,IAAMA,IAAU,MAAS,EACzC,IAAI,CAAC,CAACC,EAAMD,CAAK,IACZ,MAAM,QAAQA,CAAK,EACdA,EAAM,IAAKX,GAAMU,IAAIE,CAAI,IAAIZ,CAAC,EAAE,EAAE,KAAK,GAAG,EAE/C,OAAOW,GAAU,SACZtB,EAAQsB,EAAOF,CAAQ,EAEzBC,IAAIE,CAAI,IAAID,CAAK,EACzB,EACA,KAAK,GAAG,CACb,CAEO,SAASpB,EACdM,EACAY,EAAW,iBACH,CACR,MAAMC,KAAI,UAAOD,CAAQ,EACzB,OAAO,OAAO,QAAQZ,CAAM,EACzB,OAAO,CAAC,CAAC,CAAEc,CAAK,IAAMA,IAAU,MAAS,EACzC,IAAI,CAAC,CAACC,EAAMD,CAAK,IAAM,CACtB,MAAMX,EAAI,KAAK,UAAUW,CAAK,EAC9B,OAAOD,IAAIE,CAAI,IAAIZ,CAAC,EACtB,CAAC,EACA,KAAK,GAAG,CACb,CAEO,MAAMV,KAAO,aAAU,EACjBE,KAAO,aAAU,GAAG,EACpBE,KAAQ,aAAU,KAAK",
6
+ "names": ["query_exports", "__export", "deep", "explode", "form", "json", "pipe", "query", "space", "__toCommonJS", "import_util", "params", "s", "k", "v", "qk", "qv", "visit", "obj", "prefix", "prop", "index", "key", "encoders", "q", "value", "name"]
7
+ }
@@ -0,0 +1,20 @@
1
+ /**
2
+ * Join params using an ampersand and prepends a questionmark if not empty.
3
+ */
4
+ export declare function query(...params: string[]): string;
5
+ /**
6
+ * Serializes nested objects according to the `deepObject` style specified in
7
+ * https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.0.md#style-values
8
+ */
9
+ export declare function deep(params: Record<string, any>, [k, v]?: (typeof encodeURIComponent)[]): string;
10
+ /**
11
+ * Property values of type array or object generate separate parameters
12
+ * for each value of the array, or key-value-pair of the map.
13
+ * For other types of properties this property has no effect.
14
+ * See https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.0.0.md#encoding-object
15
+ */
16
+ export declare function explode(params: Record<string, any>, encoders?: (typeof encodeURIComponent)[]): string;
17
+ export declare function json(params: Record<string, any>, encoders?: (typeof encodeURIComponent)[]): string;
18
+ export declare const form: (params: Record<string, any>, encoders?: (typeof encodeURIComponent)[]) => string;
19
+ export declare const pipe: (params: Record<string, any>, encoders?: (typeof encodeURIComponent)[]) => string;
20
+ export declare const space: (params: Record<string, any>, encoders?: (typeof encodeURIComponent)[]) => string;
package/dist/query.mjs ADDED
@@ -0,0 +1,2 @@
1
+ import{a,b,c,d,e,f,g}from"./chunk-E3LXWSGM.mjs";import"./chunk-AU3ZD6WL.mjs";import"./chunk-T7KECS5U.mjs";export{b as deep,c as explode,e as form,d as json,f as pipe,a as query,g as space};
2
+ //# sourceMappingURL=query.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": [],
4
+ "sourcesContent": [],
5
+ "mappings": "",
6
+ "names": []
7
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,2 @@
1
+ "use strict";var J=Object.create;var R=Object.defineProperty,j=Object.defineProperties,A=Object.getOwnPropertyDescriptor,D=Object.getOwnPropertyDescriptors,U=Object.getOwnPropertyNames,b=Object.getOwnPropertySymbols,B=Object.getPrototypeOf,g=Object.prototype.hasOwnProperty,H=Object.prototype.propertyIsEnumerable;var w=(e,t,s)=>t in e?R(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s,d=(e,t)=>{for(var s in t||(t={}))g.call(t,s)&&w(e,s,t[s]);if(b)for(var s of b(t))H.call(t,s)&&w(e,s,t[s]);return e},l=(e,t)=>j(e,D(t));var O=(e,t)=>{var s={};for(var p in e)g.call(e,p)&&t.indexOf(p)<0&&(s[p]=e[p]);if(e!=null&&b)for(var p of b(e))t.indexOf(p)<0&&H.call(e,p)&&(s[p]=e[p]);return s};var W=(e,t)=>{for(var s in t)R(e,s,{get:t[s],enumerable:!0})},x=(e,t,s,p)=>{if(t&&typeof t=="object"||typeof t=="function")for(let c of U(t))!g.call(e,c)&&c!==s&&R(e,c,{get:()=>t[c],enumerable:!(p=A(t,c))||p.enumerable});return e};var k=(e,t,s)=>(s=e!=null?J(B(e)):{},x(t||!e||!e.__esModule?R(s,"default",{value:e,enumerable:!0}):s,e)),N=e=>x(R({},"__esModule",{value:!0}),e);var q=(e,t,s)=>new Promise((p,c)=>{var a=r=>{try{i(s.next(r))}catch(n){c(n)}},o=r=>{try{i(s.throw(r))}catch(n){c(n)}},i=r=>r.done?p(r.value):Promise.resolve(r.value).then(a,o);i((s=s.apply(e,t)).next())});var I={};W(I,{runtime:()=>E});module.exports=N(I);var S=k(require("./query"),1),F=require("./util"),T=require("./index"),f=require("./headers");function E(e={}){function t(a,o){return q(this,null,function*(){const i=yield c(a,o);let r;try{r=yield i.text()}catch(n){}return{status:i.status,headers:i.headers,contentType:i.headers.get("content-type"),data:r}})}function s(i){return q(this,arguments,function*(a,o={}){const{status:r,headers:n,contentType:h,data:y}=yield t(a,l(d({},o),{headers:(0,f.mergeHeaders)({Accept:"application/json"},o.headers)}));return(h?h.includes("json"):!1)?{status:r,headers:n,data:y?JSON.parse(y):null}:{status:r,headers:n,data:y}})}function p(i){return q(this,arguments,function*(a,o={}){const r=yield c(a,o);let n;try{n=yield r.blob()}catch(h){}return{status:r.status,headers:r.headers,data:n}})}function c(i){return q(this,arguments,function*(a,o={}){const u=l(d(d({},e),o),{headers:(0,f.mergeHeaders)(e.headers,o.headers)}),{baseUrl:r,fetch:n}=u,h=O(u,["baseUrl","fetch"]),y=(0,F.joinUrl)(r,a);return yield(n||fetch)(y,h)})}return{ok:T.ok,fetchText:t,fetchJson:s,fetchBlob:p,mergeHeaders:f.mergeHeaders,json(r){var n=r,{body:a,headers:o}=n,i=O(n,["body","headers"]);return l(d(d({},i),a!=null&&{body:JSON.stringify(a)}),{headers:(0,f.mergeHeaders)({"Content-Type":"application/json"},o)})},form(r){var n=r,{body:a,headers:o}=n,i=O(n,["body","headers"]);return l(d(d({},i),a!=null&&{body:S.form(a)}),{headers:(0,f.mergeHeaders)({"Content-Type":"application/x-www-form-urlencoded"},o)})},multipart(r){var n=r,{body:a,headers:o}=n,i=O(n,["body","headers"]);if(a==null)return l(d({},i),{body:a,headers:(0,f.normalizeHeaders)(o)});const h=new(e.formDataConstructor||i.formDataConstructor||FormData),y=(m,u)=>{typeof u=="string"||u instanceof Blob?h.append(m,u):h.append(m,new Blob([JSON.stringify(u)],{type:"application/json"}))};return Object.entries(a).forEach(([m,u])=>{Array.isArray(u)?u.forEach(C=>y(m,C)):y(m,u)}),l(d({},i),{body:h,headers:(0,f.normalizeHeaders)(o)})}}}
2
+ //# sourceMappingURL=runtime.cjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/runtime.ts"],
4
+ "sourcesContent": ["import * as qs from \"./query\";\nimport { joinUrl } from \"./util\";\nimport { ok } from \"./index\";\nimport { CustomHeaders, mergeHeaders, normalizeHeaders } from \"./headers\";\n\nexport { type CustomHeaders };\n\nexport type RequestOpts = {\n baseUrl?: string;\n fetch?: typeof fetch;\n formDataConstructor?: new () => FormData;\n headers?: HeadersInit | CustomHeaders;\n} & Omit<RequestInit, \"body\" | \"headers\">;\n\nexport type Defaults<Headers extends RequestOpts[\"headers\"] = CustomHeaders> =\n Omit<RequestOpts, \"headers\" | \"baseUrl\"> & {\n baseUrl: string;\n headers: Headers;\n };\n\ntype FetchRequestOpts = RequestOpts & {\n body?: string | FormData | Blob;\n};\n\ntype JsonRequestOpts = RequestOpts & {\n body?: any;\n};\n\ntype FormRequestOpts = RequestOpts & {\n body?: Record<string, any>;\n};\n\nexport type ApiResponse = { status: number; data?: any };\n\nexport type WithHeaders<T extends ApiResponse> = T & { headers: Headers };\n\ntype MultipartRequestOpts = RequestOpts & {\n body?: Record<string, unknown>;\n};\n\nexport function runtime(defaults: RequestOpts = {}) {\n async function fetchText(url: string, req?: FetchRequestOpts) {\n const res = await doFetch(url, req);\n let data;\n try {\n data = await res.text();\n } catch (err) {}\n\n return {\n status: res.status,\n headers: res.headers,\n contentType: res.headers.get(\"content-type\"),\n data,\n };\n }\n\n async function fetchJson<T extends ApiResponse>(\n url: string,\n req: FetchRequestOpts = {},\n ) {\n const { status, headers, contentType, data } = await fetchText(url, {\n ...req,\n headers: mergeHeaders(\n {\n Accept: \"application/json\",\n },\n req.headers,\n ),\n });\n\n const isJson = contentType ? contentType.includes(\"json\") : false;\n\n if (isJson) {\n return {\n status,\n headers,\n data: data ? JSON.parse(data) : null,\n } as WithHeaders<T>;\n }\n\n return { status, headers, data } as WithHeaders<T>;\n }\n\n async function fetchBlob<T extends ApiResponse>(\n url: string,\n req: FetchRequestOpts = {},\n ) {\n const res = await doFetch(url, req);\n let data;\n try {\n data = await res.blob();\n } catch (err) {}\n return { status: res.status, headers: res.headers, data } as WithHeaders<T>;\n }\n\n async function doFetch(url: string, req: FetchRequestOpts = {}) {\n const {\n baseUrl,\n fetch: customFetch,\n ...init\n } = {\n ...defaults,\n ...req,\n headers: mergeHeaders(defaults.headers, req.headers),\n };\n const href = joinUrl(baseUrl, url);\n const res = await (customFetch || fetch)(href, init);\n return res;\n }\n\n return {\n ok,\n fetchText,\n fetchJson,\n fetchBlob,\n mergeHeaders,\n\n json({ body, headers, ...req }: JsonRequestOpts) {\n return {\n ...req,\n ...(body != null && { body: JSON.stringify(body) }),\n headers: mergeHeaders(\n {\n \"Content-Type\": \"application/json\",\n },\n headers,\n ),\n };\n },\n\n form({ body, headers, ...req }: FormRequestOpts) {\n return {\n ...req,\n ...(body != null && { body: qs.form(body) }),\n headers: mergeHeaders(\n {\n \"Content-Type\": \"application/x-www-form-urlencoded\",\n },\n headers,\n ),\n };\n },\n\n multipart({ body, headers, ...req }: MultipartRequestOpts) {\n if (body == null)\n return { ...req, body, headers: normalizeHeaders(headers) };\n\n const data = new (defaults.formDataConstructor ||\n req.formDataConstructor ||\n FormData)();\n\n const append = (name: string, value: unknown) => {\n if (typeof value === \"string\" || value instanceof Blob) {\n data.append(name, value);\n } else {\n data.append(\n name,\n new Blob([JSON.stringify(value)], { type: \"application/json\" }),\n );\n }\n };\n\n Object.entries(body).forEach(([name, value]) => {\n if (Array.isArray(value)) {\n value.forEach((v) => append(name, v));\n } else {\n append(name, value);\n }\n });\n\n return {\n ...req,\n body: data,\n headers: normalizeHeaders(headers),\n };\n },\n };\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["runtime_exports", "__export", "runtime", "__toCommonJS", "qs", "import_util", "import_index", "import_headers", "runtime", "defaults", "fetchText", "url", "req", "__async", "res", "doFetch", "data", "err", "fetchJson", "_0", "status", "headers", "contentType", "__spreadProps", "__spreadValues", "fetchBlob", "_a", "baseUrl", "customFetch", "init", "__objRest", "href", "_b", "body", "_c", "_d", "_e", "_f", "append", "name", "value", "v"]
7
+ }
@@ -0,0 +1,115 @@
1
+ import { ok } from "./index";
2
+ import { CustomHeaders, mergeHeaders } from "./headers";
3
+ export { type CustomHeaders };
4
+ export type RequestOpts = {
5
+ baseUrl?: string;
6
+ fetch?: typeof fetch;
7
+ formDataConstructor?: new () => FormData;
8
+ headers?: HeadersInit | CustomHeaders;
9
+ } & Omit<RequestInit, "body" | "headers">;
10
+ export type Defaults<Headers extends RequestOpts["headers"] = CustomHeaders> = Omit<RequestOpts, "headers" | "baseUrl"> & {
11
+ baseUrl: string;
12
+ headers: Headers;
13
+ };
14
+ type FetchRequestOpts = RequestOpts & {
15
+ body?: string | FormData | Blob;
16
+ };
17
+ type JsonRequestOpts = RequestOpts & {
18
+ body?: any;
19
+ };
20
+ type FormRequestOpts = RequestOpts & {
21
+ body?: Record<string, any>;
22
+ };
23
+ export type ApiResponse = {
24
+ status: number;
25
+ data?: any;
26
+ };
27
+ export type WithHeaders<T extends ApiResponse> = T & {
28
+ headers: Headers;
29
+ };
30
+ type MultipartRequestOpts = RequestOpts & {
31
+ body?: Record<string, unknown>;
32
+ };
33
+ export declare function runtime(defaults?: RequestOpts): {
34
+ ok: typeof ok;
35
+ fetchText: (url: string, req?: FetchRequestOpts) => Promise<{
36
+ status: number;
37
+ headers: Headers;
38
+ contentType: string | null;
39
+ data: string | undefined;
40
+ }>;
41
+ fetchJson: <T extends ApiResponse>(url: string, req?: FetchRequestOpts) => Promise<WithHeaders<T>>;
42
+ fetchBlob: <T_1 extends ApiResponse>(url: string, req?: FetchRequestOpts) => Promise<WithHeaders<T_1>>;
43
+ mergeHeaders: typeof mergeHeaders;
44
+ json({ body, headers, ...req }: JsonRequestOpts): {
45
+ headers: Headers;
46
+ body?: string | undefined;
47
+ baseUrl?: string | undefined;
48
+ fetch?: typeof fetch | undefined;
49
+ formDataConstructor?: (new () => FormData) | undefined;
50
+ cache?: RequestCache | undefined;
51
+ credentials?: RequestCredentials | undefined;
52
+ integrity?: string | undefined;
53
+ keepalive?: boolean | undefined;
54
+ method?: string | undefined;
55
+ mode?: RequestMode | undefined;
56
+ redirect?: RequestRedirect | undefined;
57
+ referrer?: string | undefined;
58
+ referrerPolicy?: ReferrerPolicy | undefined;
59
+ signal?: AbortSignal | null | undefined;
60
+ window?: null | undefined;
61
+ };
62
+ form({ body, headers, ...req }: FormRequestOpts): {
63
+ headers: Headers;
64
+ body?: string | undefined;
65
+ baseUrl?: string | undefined;
66
+ fetch?: typeof fetch | undefined;
67
+ formDataConstructor?: (new () => FormData) | undefined;
68
+ cache?: RequestCache | undefined;
69
+ credentials?: RequestCredentials | undefined;
70
+ integrity?: string | undefined;
71
+ keepalive?: boolean | undefined;
72
+ method?: string | undefined;
73
+ mode?: RequestMode | undefined;
74
+ redirect?: RequestRedirect | undefined;
75
+ referrer?: string | undefined;
76
+ referrerPolicy?: ReferrerPolicy | undefined;
77
+ signal?: AbortSignal | null | undefined;
78
+ window?: null | undefined;
79
+ };
80
+ multipart({ body, headers, ...req }: MultipartRequestOpts): {
81
+ body: undefined;
82
+ headers: Headers;
83
+ baseUrl?: string | undefined;
84
+ fetch?: typeof fetch | undefined;
85
+ formDataConstructor?: (new () => FormData) | undefined;
86
+ cache?: RequestCache | undefined;
87
+ credentials?: RequestCredentials | undefined;
88
+ integrity?: string | undefined;
89
+ keepalive?: boolean | undefined;
90
+ method?: string | undefined;
91
+ mode?: RequestMode | undefined;
92
+ redirect?: RequestRedirect | undefined;
93
+ referrer?: string | undefined;
94
+ referrerPolicy?: ReferrerPolicy | undefined;
95
+ signal?: AbortSignal | null | undefined;
96
+ window?: null | undefined;
97
+ } | {
98
+ body: FormData;
99
+ headers: Headers;
100
+ baseUrl?: string | undefined;
101
+ fetch?: typeof fetch | undefined;
102
+ formDataConstructor?: (new () => FormData) | undefined;
103
+ cache?: RequestCache | undefined;
104
+ credentials?: RequestCredentials | undefined;
105
+ integrity?: string | undefined;
106
+ keepalive?: boolean | undefined;
107
+ method?: string | undefined;
108
+ mode?: RequestMode | undefined;
109
+ redirect?: RequestRedirect | undefined;
110
+ referrer?: string | undefined;
111
+ referrerPolicy?: ReferrerPolicy | undefined;
112
+ signal?: AbortSignal | null | undefined;
113
+ window?: null | undefined;
114
+ };
115
+ };
@@ -0,0 +1,2 @@
1
+ import{a}from"./chunk-LUOVPBCG.mjs";import"./chunk-E3LXWSGM.mjs";import"./chunk-AU3ZD6WL.mjs";import"./chunk-6C7A2H7M.mjs";import"./chunk-T7KECS5U.mjs";export{a as runtime};
2
+ //# sourceMappingURL=runtime.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": [],
4
+ "sourcesContent": [],
5
+ "mappings": "",
6
+ "names": []
7
+ }
package/dist/util.cjs ADDED
@@ -0,0 +1,2 @@
1
+ "use strict";var a=Object.defineProperty;var f=Object.getOwnPropertyDescriptor;var l=Object.getOwnPropertyNames;var y=Object.prototype.hasOwnProperty;var m=(r,e)=>{for(var t in e)a(r,t,{get:e[t],enumerable:!0})},g=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of l(e))!y.call(r,o)&&o!==t&&a(r,o,{get:()=>e[o],enumerable:!(n=f(e,o))||n.enumerable});return r};var j=r=>g(a({},"__esModule",{value:!0}),r);var A={};m(A,{allowReserved:()=>R,delimited:()=>$,encode:()=>u,encodeReserved:()=>p,joinUrl:()=>x});module.exports=j(A);const p=[encodeURIComponent,encodeURIComponent],R=[encodeURIComponent,encodeURI];function u(r,e=","){const t=(n,o)=>{const c=r[o%r.length];return typeof n=="undefined"?"":typeof n=="object"?Array.isArray(n)?n.map(c).join(e):Object.entries(n).reduce((i,s)=>[...i,...s],[]).map(c).join(e):c(String(n))};return(n,...o)=>n.reduce((c,d,i)=>`${c}${d}${t(o[i],i)}`,"")}function $(r=","){return(e,t=p)=>Object.entries(e).filter(([,n])=>n!==void 0).map(([n,o])=>u(t,r)`${n}=${o}`).join("&")}function x(...r){return r.filter(Boolean).map((e,t)=>t===0?e:e.replace(/^\/+/,"")).map((e,t,n)=>t===n.length-1?e:e.replace(/\/+$/,"")).join("/")}
2
+ //# sourceMappingURL=util.cjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/util.ts"],
4
+ "sourcesContent": ["type Encoders = Array<(s: string) => string>;\n\n// Encode param names and values as URIComponent\nexport const encodeReserved = [encodeURIComponent, encodeURIComponent];\nexport const allowReserved = [encodeURIComponent, encodeURI];\n\n/**\n * Creates a tag-function to encode template strings with the given encoders.\n */\nexport function encode(encoders: Encoders, delimiter = \",\") {\n const q = (v: any, i: number) => {\n const encoder = encoders[i % encoders.length];\n if (typeof v === \"undefined\") {\n return \"\";\n }\n if (typeof v === \"object\") {\n if (Array.isArray(v)) {\n return v.map(encoder).join(delimiter);\n }\n const flat = Object.entries(v).reduce(\n (flat, entry) => [...flat, ...entry],\n [] as any,\n );\n return flat.map(encoder).join(delimiter);\n }\n\n return encoder(String(v));\n };\n\n return (strings: TemplateStringsArray, ...values: any[]) => {\n return strings.reduce((prev, s, i) => {\n return `${prev}${s}${q(values[i], i)}`;\n }, \"\");\n };\n}\n\n/**\n * Separate array values by the given delimiter.\n */\nexport function delimited(delimiter = \",\") {\n return (params: Record<string, any>, encoders = encodeReserved) =>\n Object.entries(params)\n .filter(([, value]) => value !== undefined)\n .map(([name, value]) => encode(encoders, delimiter)`${name}=${value}`)\n .join(\"&\");\n}\n\nexport function joinUrl(...parts: Array<string | undefined>) {\n return parts\n .filter(Boolean)\n .map((s, i) => (i === 0 ? s : s!.replace(/^\\/+/, \"\")))\n .map((s, i, a) => (i === a.length - 1 ? s : s!.replace(/\\/+$/, \"\")))\n .join(\"/\");\n}\n"],
5
+ "mappings": "yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,mBAAAE,EAAA,cAAAC,EAAA,WAAAC,EAAA,mBAAAC,EAAA,YAAAC,IAAA,eAAAC,EAAAP,GAGO,MAAMK,EAAiB,CAAC,mBAAoB,kBAAkB,EACxDH,EAAgB,CAAC,mBAAoB,SAAS,EAKpD,SAASE,EAAOI,EAAoBC,EAAY,IAAK,CAC1D,MAAMC,EAAI,CAACC,EAAQC,IAAc,CAC/B,MAAMC,EAAUL,EAASI,EAAIJ,EAAS,MAAM,EAC5C,OAAI,OAAOG,GAAM,YACR,GAEL,OAAOA,GAAM,SACX,MAAM,QAAQA,CAAC,EACVA,EAAE,IAAIE,CAAO,EAAE,KAAKJ,CAAS,EAEzB,OAAO,QAAQE,CAAC,EAAE,OAC7B,CAACG,EAAMC,IAAU,CAAC,GAAGD,EAAM,GAAGC,CAAK,EACnC,CAAC,CACH,EACY,IAAIF,CAAO,EAAE,KAAKJ,CAAS,EAGlCI,EAAQ,OAAOF,CAAC,CAAC,CAC1B,EAEA,MAAO,CAACK,KAAkCC,IACjCD,EAAQ,OAAO,CAACE,EAAMC,EAAG,IACvB,GAAGD,CAAI,GAAGC,CAAC,GAAGT,EAAEO,EAAO,CAAC,EAAG,CAAC,CAAC,GACnC,EAAE,CAET,CAKO,SAASd,EAAUM,EAAY,IAAK,CACzC,MAAO,CAACW,EAA6BZ,EAAWH,IAC9C,OAAO,QAAQe,CAAM,EAClB,OAAO,CAAC,CAAC,CAAEC,CAAK,IAAMA,IAAU,MAAS,EACzC,IAAI,CAAC,CAACC,EAAMD,CAAK,IAAMjB,EAAOI,EAAUC,CAAS,IAAIa,CAAI,IAAID,CAAK,EAAE,EACpE,KAAK,GAAG,CACf,CAEO,SAASf,KAAWiB,EAAkC,CAC3D,OAAOA,EACJ,OAAO,OAAO,EACd,IAAI,CAACJ,EAAGP,IAAOA,IAAM,EAAIO,EAAIA,EAAG,QAAQ,OAAQ,EAAE,CAAE,EACpD,IAAI,CAACA,EAAGP,EAAGY,IAAOZ,IAAMY,EAAE,OAAS,EAAIL,EAAIA,EAAG,QAAQ,OAAQ,EAAE,CAAE,EAClE,KAAK,GAAG,CACb",
6
+ "names": ["util_exports", "__export", "allowReserved", "delimited", "encode", "encodeReserved", "joinUrl", "__toCommonJS", "encoders", "delimiter", "q", "v", "i", "encoder", "flat", "entry", "strings", "values", "prev", "s", "params", "value", "name", "parts", "a"]
7
+ }
package/dist/util.d.ts ADDED
@@ -0,0 +1,13 @@
1
+ type Encoders = Array<(s: string) => string>;
2
+ export declare const encodeReserved: (typeof encodeURIComponent)[];
3
+ export declare const allowReserved: (typeof encodeURI)[];
4
+ /**
5
+ * Creates a tag-function to encode template strings with the given encoders.
6
+ */
7
+ export declare function encode(encoders: Encoders, delimiter?: string): (strings: TemplateStringsArray, ...values: any[]) => string;
8
+ /**
9
+ * Separate array values by the given delimiter.
10
+ */
11
+ export declare function delimited(delimiter?: string): (params: Record<string, any>, encoders?: (typeof encodeURIComponent)[]) => string;
12
+ export declare function joinUrl(...parts: Array<string | undefined>): string;
13
+ export {};
package/dist/util.mjs ADDED
@@ -0,0 +1,2 @@
1
+ import{a,b,c,d,e}from"./chunk-AU3ZD6WL.mjs";import"./chunk-T7KECS5U.mjs";export{b as allowReserved,d as delimited,c as encode,a as encodeReserved,e as joinUrl};
2
+ //# sourceMappingURL=util.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": [],
4
+ "sourcesContent": [],
5
+ "mappings": "",
6
+ "names": []
7
+ }
@@ -0,0 +1 @@
1
+ export {};
package/package.json ADDED
@@ -0,0 +1,58 @@
1
+ {
2
+ "name": "@oazapfts/runtime",
3
+ "version": "0.0.1-start",
4
+ "description": "Runtime for OpenApi TypeScript client generator",
5
+ "type": "module",
6
+ "main": "dist/index.cjs",
7
+ "module": "dist/index.mjs",
8
+ "types": "dist/index.d.ts",
9
+ "exports": {
10
+ ".": {
11
+ "types": "./dist/index.d.ts",
12
+ "require": "./dist/index.cjs",
13
+ "import": "./dist/index.mjs"
14
+ },
15
+ "./query": {
16
+ "types": "./dist/query.d.ts",
17
+ "require": "./dist/query.cjs",
18
+ "import": "./dist/query.mjs"
19
+ },
20
+ "./util": {
21
+ "types": "./dist/util.d.ts",
22
+ "require": "./dist/util.cjs",
23
+ "import": "./dist/util.mjs"
24
+ },
25
+ "./headers": {
26
+ "types": "./dist/headers.d.ts",
27
+ "require": "./dist/headers.cjs",
28
+ "import": "./dist/headers.mjs"
29
+ }
30
+ },
31
+ "license": "MIT",
32
+ "repository": "oazapfts/oazapfts",
33
+ "scripts": {
34
+ "build": "rm -rf dist && tsc && node ./build.js"
35
+ },
36
+ "release": {
37
+ "extends": "semantic-release-monorepo",
38
+ "branches": [
39
+ "+([0-9])?(.{+([0-9]),x}).x",
40
+ "main",
41
+ {
42
+ "name": "beta",
43
+ "prerelease": true
44
+ },
45
+ {
46
+ "name": "alpha",
47
+ "prerelease": true
48
+ }
49
+ ]
50
+ },
51
+ "keywords": [
52
+ "openapi",
53
+ "typescript",
54
+ "runtime",
55
+ "http",
56
+ "oazapfts"
57
+ ]
58
+ }