zenko 0.1.12 → 0.1.14
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 +122 -2
- package/dist/chunk-64LDA5YF.mjs +11 -0
- package/dist/chunk-XXHDWDVY.cjs +11 -0
- package/dist/cli.cjs +1 -1741
- package/dist/cli.mjs +1 -1718
- package/dist/index.cjs +1 -1535
- package/dist/index.d.cts +5 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.mjs +1 -1508
- package/package.json +12 -4
- package/dist/cli.cjs.map +0 -1
- package/dist/cli.mjs.map +0 -1
- package/dist/index.cjs.map +0 -1
- package/dist/index.mjs.map +0 -1
package/README.md
CHANGED
|
@@ -67,9 +67,12 @@ The config file controls generation for multiple specs and can also configure ty
|
|
|
67
67
|
|
|
68
68
|
```json
|
|
69
69
|
{
|
|
70
|
+
"$schema": "https://raw.githubusercontent.com/RawToast/zenko/refs/heads/master/packages/zenko/zenko-config.schema.json",
|
|
70
71
|
"types": {
|
|
71
72
|
"emit": true,
|
|
72
|
-
"helpers": "package"
|
|
73
|
+
"helpers": "package",
|
|
74
|
+
"treeShake": true,
|
|
75
|
+
"optionalType": "optional"
|
|
73
76
|
},
|
|
74
77
|
"schemas": [
|
|
75
78
|
{
|
|
@@ -84,6 +87,16 @@ The config file controls generation for multiple specs and can also configure ty
|
|
|
84
87
|
"types": {
|
|
85
88
|
"helpers": "inline"
|
|
86
89
|
}
|
|
90
|
+
},
|
|
91
|
+
{
|
|
92
|
+
"input": "my-custom-api.yaml",
|
|
93
|
+
"output": "my-custom-api.gen.ts",
|
|
94
|
+
"operationIds": ["getUser", "createUser", "updateUser"],
|
|
95
|
+
"types": {
|
|
96
|
+
"helpers": "file",
|
|
97
|
+
"helpersOutput": "./shared/api-helpers.ts",
|
|
98
|
+
"treeShake": false
|
|
99
|
+
}
|
|
87
100
|
}
|
|
88
101
|
]
|
|
89
102
|
}
|
|
@@ -96,6 +109,110 @@ The config file controls generation for multiple specs and can also configure ty
|
|
|
96
109
|
- `helpers: "file"` imports from a custom module (`helpersOutput` path)
|
|
97
110
|
- `emit: false` disables per-operation type aliases entirely
|
|
98
111
|
|
|
112
|
+
#### Additional Type Configuration
|
|
113
|
+
|
|
114
|
+
- `treeShake: true` (default) - Only generates types used in operations
|
|
115
|
+
- `treeShake: false` - Generates all types from the schema
|
|
116
|
+
- `optionalType: "optional"` (default) - Fields can be undefined (`z.optional()`)
|
|
117
|
+
- `optionalType: "nullable"` - Fields can be null (`z.nullable()`)
|
|
118
|
+
- `optionalType: "nullish"` - Fields can be undefined or null (`z.nullish()`)
|
|
119
|
+
|
|
120
|
+
#### Selective Operations
|
|
121
|
+
|
|
122
|
+
Generate only specific operations using `operationIds`:
|
|
123
|
+
|
|
124
|
+
```json
|
|
125
|
+
{
|
|
126
|
+
"$schema": "https://raw.githubusercontent.com/RawToast/zenko/refs/heads/master/packages/zenko/zenko-config.schema.json",
|
|
127
|
+
"schemas": [
|
|
128
|
+
{
|
|
129
|
+
"input": "api.yaml",
|
|
130
|
+
"output": "api.gen.ts",
|
|
131
|
+
"operationIds": ["getUser", "createUser", "updateUser"]
|
|
132
|
+
}
|
|
133
|
+
]
|
|
134
|
+
}
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
#### Open Enums
|
|
138
|
+
|
|
139
|
+
By default, enums are "closed" - they only accept the values defined in your OpenAPI spec. Open enums allow unknown string values to pass through, which is useful when APIs may add new enum values without breaking existing clients.
|
|
140
|
+
|
|
141
|
+
Unknown values are transformed to a prefixed string (default: `` `Unknown:${value}` ``), making them easy to identify and handle.
|
|
142
|
+
|
|
143
|
+
**Basic usage:**
|
|
144
|
+
|
|
145
|
+
```json
|
|
146
|
+
{
|
|
147
|
+
"schemas": [
|
|
148
|
+
{
|
|
149
|
+
"input": "api.yaml",
|
|
150
|
+
"output": "api.gen.ts",
|
|
151
|
+
"openEnums": true
|
|
152
|
+
}
|
|
153
|
+
]
|
|
154
|
+
}
|
|
155
|
+
```
|
|
156
|
+
|
|
157
|
+
**Selective enums:**
|
|
158
|
+
|
|
159
|
+
```json
|
|
160
|
+
{
|
|
161
|
+
"schemas": [
|
|
162
|
+
{
|
|
163
|
+
"input": "api.yaml",
|
|
164
|
+
"output": "api.gen.ts",
|
|
165
|
+
"openEnums": ["Status", "Category"]
|
|
166
|
+
}
|
|
167
|
+
]
|
|
168
|
+
}
|
|
169
|
+
```
|
|
170
|
+
|
|
171
|
+
**Custom prefix:**
|
|
172
|
+
|
|
173
|
+
If `"Unknown:"` conflicts with your schema values or you prefer a different convention, use the object form:
|
|
174
|
+
|
|
175
|
+
```json
|
|
176
|
+
{
|
|
177
|
+
"schemas": [
|
|
178
|
+
{
|
|
179
|
+
"input": "api.yaml",
|
|
180
|
+
"output": "api.gen.ts",
|
|
181
|
+
"openEnums": {
|
|
182
|
+
"open": true,
|
|
183
|
+
"unknownPrefix": "unrecognized_"
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
]
|
|
187
|
+
}
|
|
188
|
+
```
|
|
189
|
+
|
|
190
|
+
Or combine selective enums with a custom prefix:
|
|
191
|
+
|
|
192
|
+
```json
|
|
193
|
+
{
|
|
194
|
+
"openEnums": { "open": ["Status"], "unknownPrefix": "x-" }
|
|
195
|
+
}
|
|
196
|
+
```
|
|
197
|
+
|
|
198
|
+
**Generated output:**
|
|
199
|
+
|
|
200
|
+
```typescript
|
|
201
|
+
// Closed enum (default)
|
|
202
|
+
export const Category = z.enum(["electronics", "clothing", "books"])
|
|
203
|
+
|
|
204
|
+
// Open enum
|
|
205
|
+
const StatusKnown = ["active", "inactive", "pending"] as const
|
|
206
|
+
export const Status = z
|
|
207
|
+
.enum(StatusKnown)
|
|
208
|
+
.or(z.string().transform((v): `Unknown:${string}` => `Unknown:${v}`))
|
|
209
|
+
|
|
210
|
+
// TypeScript type includes both known and unknown values
|
|
211
|
+
type Status = "active" | "inactive" | "pending" | `Unknown:${string}`
|
|
212
|
+
```
|
|
213
|
+
|
|
214
|
+
**Note:** When specifying enum names in `openEnums`, use the sanitized TypeScript name (e.g., `"LinksSelf"` not `"Links-Self"`). Schema names with hyphens are converted to camelCase.
|
|
215
|
+
|
|
99
216
|
### Programmatic Usage
|
|
100
217
|
|
|
101
218
|
```typescript
|
|
@@ -230,6 +347,9 @@ if (validation.success) {
|
|
|
230
347
|
|
|
231
348
|
### Building a Generic Client
|
|
232
349
|
|
|
350
|
+
Below is an example of a generic client that can be used to run operations.
|
|
351
|
+
See [examples package](../examples/README.md) for a more complete examples with tests, using undici, fetch, ts-effect.
|
|
352
|
+
|
|
233
353
|
```typescript
|
|
234
354
|
import type { OperationDefinition } from "zenko"
|
|
235
355
|
|
|
@@ -256,7 +376,7 @@ async function runOperation<
|
|
|
256
376
|
|
|
257
377
|
### Dependency Resolution
|
|
258
378
|
|
|
259
|
-
Zenko automatically resolves schema dependencies using topological sorting, ensuring that referenced types are defined before they're used. This eliminates "used before declaration" errors.
|
|
379
|
+
Zenko automatically resolves schema dependencies using topological sorting, ensuring that referenced types are defined before they're used. This eliminates "used before declaration" errors. Alongside excessive duplicate schema generation, as found in other generators.
|
|
260
380
|
|
|
261
381
|
### Zod Integration
|
|
262
382
|
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
function V(e){let n=new Set,t=new Set,r=[],s=i=>{if(n.has(i)||t.has(i))return;t.add(i);let o=e[i],p=q(o);for(let a of p)e[a]&&s(a);t.delete(i),n.add(i),r.push(i)};for(let i of Object.keys(e))s(i);return r}function q(e){let n=[],t=r=>{if(!(typeof r!="object"||r===null)){if(r.$ref&&typeof r.$ref=="string"){let s=g(r.$ref);n.push(s);return}Array.isArray(r)?r.forEach(t):Object.values(r).forEach(t)}};return t(e),[...new Set(n)]}function g(e){return e.split("/").pop()||"Unknown"}function I(e){if(!e)return!1;let n=e.at(0);return n===void 0||!/[a-zA-Z_$]/.test(n)||!/^[a-zA-Z_$][a-zA-Z0-9_$]*$/.test(e)?!1:!new Set(["abstract","arguments","await","boolean","break","byte","case","catch","char","class","const","continue","debugger","default","delete","do","double","else","enum","eval","export","extends","false","final","finally","float","for","function","goto","if","implements","import","in","instanceof","int","interface","let","long","native","new","null","package","private","protected","public","return","short","static","super","switch","synchronized","this","throw","throws","transient","true","try","typeof","var","void","volatile","while","with","yield","async"]).has(e)}function l(e){return I(e)?e:`"${e}"`}function O(e){return e.replace(/-([a-zA-Z])/g,(n,t)=>t.toUpperCase()).replace(/-+$/,"")}function b(e){return e.charAt(0).toUpperCase()+e.slice(1)}function F(e){let n={usesHeaderFn:!1,usesOperationDefinition:!1,usesOperationErrors:!1};e.length>0&&(n.usesOperationDefinition=!0);for(let t of e)t.errors&&W(t.errors)&&(n.usesOperationErrors=!0);return e.length>0&&!n.usesOperationErrors&&e.some(r=>!r.errors||!W(r.errors))&&(n.usesOperationErrors=!0),n}function G(e,n,t){let r=[];if(e.usesHeaderFn&&r.push("HeaderFn"),e.usesOperationDefinition&&r.push("OperationDefinition"),e.usesOperationErrors&&r.push("OperationErrors"),r.length===0)return"";let s=n==="package"?'"zenko"':`"${t}"`;return`import type { ${r.join(", ")} } from ${s};`}function W(e){return!!(e&&Object.keys(e).length>0)}var v={"application/json":"unknown","text/csv":"string","text/plain":"string","application/octet-stream":"unknown","application/pdf":"unknown"};function N(e){let n=Object.keys(e);if(n.includes("application/json"))return"application/json";for(let t of n)if(t in v)return t;return n[0]||""}function j(e,n){if(e){if(e.$ref){let t=g(e.$ref),r=n.components?.parameters?.[t];if(!r)return;let{$ref:s,...i}=e;return{...r,...i}}return e}}function J(e,n){let t=new Set,r=new Map;for(let[,o]of Object.entries(n.paths||{}))for(let[,p]of Object.entries(o)){let a=p;a.operationId&&r.set(a.operationId,a)}for(let[,o]of Object.entries(n.webhooks||{}))for(let[,p]of Object.entries(o)){let a=p;a.operationId&&r.set(a.operationId,a)}for(let o of e){let p=r.get(o.operationId);if(!p)continue;let a=p.requestBody?.content?.["application/json"]?.schema;if(a?.$ref){let f=g(a.$ref);t.add(f)}else if(a){let f=q(a);for(let c of f)n.components?.schemas?.[c]&&t.add(c)}let y=p.responses||{};for(let[,f]of Object.entries(y)){let c=f?.content;if(!c)continue;let $=N(c),u=c[$]?.schema;if(u?.$ref){let m=g(u.$ref);t.add(m)}else if(u){let m=q(u);for(let T of m)n.components?.schemas?.[T]&&t.add(T)}}for(let f of o.queryParams){if(f.schema?.$ref){let c=g(f.schema.$ref);t.add(c)}if(f.schema?.items?.$ref){let c=g(f.schema.items.$ref);t.add(c)}}for(let f of o.requestHeaders||[]){if(f.schema?.$ref){let c=g(f.schema.$ref);t.add(c)}if(f.schema?.items?.$ref){let c=g(f.schema.items.$ref);t.add(c)}}let h=p.parameters||[];for(let f of h){let c=j(f,n);if(c?.schema?.$ref){let $=g(c.schema.$ref);t.add($)}if(c?.schema?.items?.$ref){let $=g(c.schema.items.$ref);t.add($)}}}let s=new Set,i=Array.from(t);for(;i.length>0;){let o=i.pop();if(s.has(o))continue;s.add(o);let p=n.components?.schemas?.[o];if(!p)continue;let a=q(p);for(let y of a)n.components?.schemas?.[y]&&!s.has(y)&&(t.add(y),i.push(y))}return t}function xe(e,n){return n===!0?!0:Array.isArray(n)?n.includes(e):!1}function D(e,n){switch(n){case"optional":return`${e}.optional()`;case"nullable":return`${e}.nullable()`;case"nullish":return`${e}.nullish()`}}function z(e,n,t,r,s){if(t.has(e))return"";if(t.add(e),n.enum){let i=n.enum.map(o=>`"${o}"`).join(", ");if(xe(e,r.openEnums)){let o=r.openEnumPrefix;return`const ${e}Known = [${i}] as const;
|
|
2
|
+
export const ${e} = z.enum(${e}Known).or(
|
|
3
|
+
z.string().transform((v): \`${o}\${string}\` => \`${o}\${v}\`)
|
|
4
|
+
);`}return`export const ${e} = z.enum([${i}]);`}if(n.allOf&&Array.isArray(n.allOf)){let i=n.allOf.map(a=>A(a,r,s));if(i.length===0)return`export const ${e} = z.object({});`;if(i.length===1)return`export const ${e} = ${i[0]};`;let o=i[0],p=i.slice(1).map(a=>`.and(${a})`).join("");return`export const ${e} = ${o}${p};`}if(n.type==="object"||n.properties)return`export const ${e} = ${K(n,r,s)};`;if(n.type==="array"){let i=n.items??{type:"unknown"},o=A(i,r,s),p=be(n,`z.array(${o})`,i,r.strictNumeric);return`export const ${e} = ${p};`}return`export const ${e} = ${A(n,r,s)};`}function A(e,n,t){if(e.$ref){let r=g(e.$ref);return t?.get(r)||r}if(e.enum)return`z.enum([${e.enum.map(s=>`"${s}"`).join(", ")}])`;if(e.allOf&&Array.isArray(e.allOf)){let r=e.allOf.map(o=>A(o,n,t));if(r.length===0)return"z.object({})";if(r.length===1)return r[0];let s=r[0],i=r.slice(1).map(o=>`.and(${o})`).join("");return`${s}${i}`}if(e.type==="object"||e.properties||e.allOf||e.oneOf||e.anyOf)return K(e,n,t);switch(e.type){case"string":return Se(e,n);case"boolean":return"z.boolean()";case"array":return`z.array(${A(e.items??{type:"unknown"},n,t)})`;case"null":return"z.null()";case"number":return Y(e,n);case"integer":return Ie(e,n);default:return"z.unknown()"}}function K(e,n,t){let r=[];for(let[s,i]of Object.entries(e.properties||{})){let o=e.required?.includes(s)??!1,p=A(i,n,t),a=D(p,n.optionalType),y=n.optionalType!=="nullable"?we(a,i):a,h=o?p:y;r.push(` ${l(s)}: ${h},`)}return r.length===0?"z.object({})":`z.object({
|
|
5
|
+
${r.join(`
|
|
6
|
+
`)}
|
|
7
|
+
})`}function Se(e,n){if(e.format==="binary")return'(typeof Blob === "undefined" ? z.unknown() : z.instanceof(Blob))';if(n.strictDates)switch(e.format){case"date-time":return"z.string().datetime()";case"date":return"z.string().date()";case"time":return"z.string().time()";case"duration":return"z.string().duration()"}let t="z.string()";switch(n.strictNumeric&&(typeof e.minLength=="number"&&(t+=`.min(${e.minLength})`),typeof e.maxLength=="number"&&(t+=`.max(${e.maxLength})`),e.pattern&&(t+=`.regex(new RegExp(${JSON.stringify(e.pattern)}))`)),e.format){case"uuid":return`${t}.uuid()`;case"email":return`${t}.email()`;case"uri":case"url":return`${t}.url()`;case"ipv4":return`${t}.ip({ version: "v4" })`;case"ipv6":return`${t}.ip({ version: "v6" })`;default:return t}}function we(e,n){return!n||n.default===void 0?e:`${e}.default(${JSON.stringify(n.default)})`}function Y(e,n){let t="z.number()";return n.strictNumeric&&(t=Re(e,t),typeof e.multipleOf=="number"&&e.multipleOf!==0&&(t+=`.refine((value) => Math.abs(value / ${e.multipleOf} - Math.round(value / ${e.multipleOf})) < Number.EPSILON, { message: "Must be a multiple of ${e.multipleOf}" })`)),t}function Ie(e,n){let t=Y(e,n);return t+=".int()",t}function be(e,n,t,r){return r&&(typeof e.minItems=="number"&&(n+=`.min(${e.minItems})`),typeof e.maxItems=="number"&&(n+=`.max(${e.maxItems})`),e.uniqueItems&&Pe(t)&&(n+='.refine((items) => new Set(items).size === items.length, { message: "Items must be unique" })')),n}function Pe(e){return e?.$ref?!1:new Set(["string","number","integer","boolean"]).has(e?.type)}function Re(e,n){return typeof e.minimum=="number"?e.exclusiveMinimum===!0?n+=`.gt(${e.minimum})`:n+=`.min(${e.minimum})`:typeof e.exclusiveMinimum=="number"&&(n+=`.gt(${e.exclusiveMinimum})`),typeof e.maximum=="number"?e.exclusiveMaximum===!0?n+=`.lt(${e.maximum})`:n+=`.max(${e.maximum})`:typeof e.exclusiveMaximum=="number"&&(n+=`.lt(${e.exclusiveMaximum})`),n}var ke={400:"badRequest",401:"unauthorized",402:"paymentRequired",403:"forbidden",404:"notFound",405:"methodNotAllowed",406:"notAcceptable",407:"proxyAuthenticationRequired",408:"requestTimeout",409:"conflict",410:"gone",411:"lengthRequired",412:"preconditionFailed",413:"payloadTooLarge",414:"uriTooLong",415:"unsupportedMediaType",416:"rangeNotSatisfiable",417:"expectationFailed",418:"imATeapot",421:"misdirectedRequest",422:"unprocessableEntity",423:"locked",424:"failedDependency",425:"tooEarly",426:"upgradeRequired",428:"preconditionRequired",429:"tooManyRequests",431:"requestHeaderFieldsTooLarge",451:"unavailableForLegalReasons",500:"internalServerError",501:"notImplemented",502:"badGateway",503:"serviceUnavailable",504:"gatewayTimeout",505:"httpVersionNotSupported",506:"variantAlsoNegotiates",507:"insufficientStorage",508:"loopDetected",510:"notExtended",511:"networkAuthenticationRequired"};function X(e){if(e==="default")return"defaultError";let n=e.trim(),t=ke[n];if(t)return t;if(/^\d{3}$/.test(n))return`status${n}`;let r=n.toLowerCase().replace(/[^a-z0-9]+/g," ").trim();if(!r)return"unknownError";let s=r.split(/\s+/),[i,...o]=s,p=i+o.map(a=>a.charAt(0).toUpperCase()+a.slice(1)).join("");return p?/^[a-zA-Z_$]/.test(p)?p:`status${p.charAt(0).toUpperCase()}${p.slice(1)}`:"unknownError"}function M(e){if(e==="default")return!0;let n=Number(e);return Number.isInteger(n)?n>=400:!1}function ae(e,n){let t=[];if(e.paths)for(let[r,s]of Object.entries(e.paths))for(let[i,o]of Object.entries(s)){let p=i.toLowerCase();if(!ie(p)||!o.operationId)continue;let a=te(r),y=ne(o,n),{successResponse:h,errors:f}=re(o,o.operationId,n),c=ee(s,o,e),$=oe(c),u=se(c);t.push({operationId:o.operationId,path:r,method:p,pathParams:a,queryParams:u,requestType:y,responseType:h,requestHeaders:$,errors:f})}if(e.webhooks)for(let[r,s]of Object.entries(e.webhooks))for(let[i,o]of Object.entries(s)){let p=i.toLowerCase();if(!ie(p)||!o.operationId)continue;let a=r,y=te(a),h=ne(o,n),{successResponse:f,errors:c}=re(o,o.operationId,n),$=ee(s,o,e),u=oe($),m=se($);t.push({operationId:o.operationId,path:a,method:p,pathParams:y,queryParams:m,requestType:h,responseType:f,requestHeaders:u,errors:c})}return t}function ee(e,n,t){let r=new Map,s=i=>{if(Array.isArray(i))for(let o of i){let p=j(o,t);if(!p)continue;let a=`${p.in}:${p.name}`;r.set(a,p)}};return s(e.parameters),s(n.parameters),Array.from(r.values())}function te(e){let n=[],t=e.match(/{([^}]+)}/g);if(t)for(let r of t){let s=r.slice(1,-1);n.push({name:s,type:"string"})}return n}function ne(e,n){let t=Ae(e);if(!t)return;if(t.$ref){let s=g(t.$ref);return n?.get(s)||s}return`${b(O(e.operationId))}Request`}function Ae(e){let n=e?.requestBody?.content;if(!n||Object.keys(n).length===0)return;let t=["application/json","multipart/form-data","application/x-www-form-urlencoded"];for(let r of t){let s=n[r]?.schema;if(s)return s}}function re(e,n,t){let r=e.responses??{},s=new Map,i=[];for(let[a,y]of Object.entries(r)){let h=y?.content;if(!h||Object.keys(h).length===0){a==="204"||/^3\d\d$/.test(a)?s.set(a,"undefined"):M(a)&&i.push({code:a,schema:"undefined"});continue}let f=N(h),c=h[f]?.schema;if(!c){let $=Ee(f,a);$&&(M(a)?i.push({code:a,schema:$}):/^2\d\d$/.test(a)&&s.set(a,$));continue}if(M(a)){i.push({code:a,schema:c});continue}/^2\d\d$/.test(a)&&s.set(a,c)}let o=qe(s,n,t),p=ze(i,n,t);return{successResponse:o,errors:p}}function qe(e,n,t){if(e.size===0)return;let r=["200","201","204"];for(let i of r){let o=e.get(i);if(o)return typeof o=="string"?o:Z(o,`${b(O(n))}Response`,t)}let[,s]=e.entries().next().value??[];if(s)return typeof s=="string"?s:Z(s,`${b(O(n))}Response`,t)}function ze(e=[],n,t){if(!e.length)return;let r={};for(let{code:s,schema:i}of e){let o=X(s),p=Z(i,`${b(O(n))}${b(o)}`,t);r[o]=p}return r}function Z(e,n,t){if(typeof e=="string")return e;if(e.$ref){let r=g(e.$ref);return t?.get(r)||r}if(e.type==="array"&&e.items?.$ref){let r=g(e.items.$ref);return`z.array(${t?.get(r)||r})`}return e.allOf&&Array.isArray(e.allOf),n}function oe(e){let n=[];for(let t of e??[])t.in==="header"&&n.push({name:t.name,description:t.description,schema:t.schema,required:t.required});return n}function se(e){let n=[];for(let t of e??[])t.in==="query"&&n.push({name:t.name,description:t.description,schema:t.schema,required:t.required});return n}function ie(e){switch(e){case"get":case"put":case"post":case"delete":case"options":case"head":case"patch":case"trace":return!0;default:return!1}}function Ee(e,n){return n==="204"||/^3\d\d$/.test(n)?"undefined":e in v?v[e]:"unknown"}function pe(e,n){let t=new Map,r=new Map;for(let[,s]of Object.entries(n.paths||{}))for(let[,i]of Object.entries(s)){let o=i;o.operationId&&r.set(o.operationId,o)}for(let[,s]of Object.entries(n.webhooks||{}))for(let[,i]of Object.entries(s)){let o=i;o.operationId&&r.set(o.operationId,o)}for(let s of e){let i=r.get(s.operationId);if(!i)continue;let o=i.requestBody;if(o&&o.content){let p=o.content,a=ve(p);if(!a)continue;let y=`${b(O(s.operationId))}Request`;(!a.$ref||a.allOf||a.oneOf||a.anyOf)&&t.set(y,a)}}return t}function ve(e){let n=["application/json","multipart/form-data","application/x-www-form-urlencoded"];for(let t of n){let r=e[t]?.schema;if(r)return r}}function ue(e,n){let t=new Map,r=new Map;for(let[,s]of Object.entries(n.paths||{}))for(let[,i]of Object.entries(s)){let o=i;o.operationId&&r.set(o.operationId,o)}for(let[,s]of Object.entries(n.webhooks||{}))for(let[,i]of Object.entries(s)){let o=i;o.operationId&&r.set(o.operationId,o)}for(let s of e){let i=r.get(s.operationId);if(!i)continue;let o=i.responses||{};for(let[p,a]of Object.entries(o))if(/^2\d\d$/.test(p)&&a.content){let h=a.content["application/json"];if(h&&h.schema){let f=h.schema,c=`${b(O(s.operationId))}Response`;(!f.$ref||f.allOf||f.oneOf||f.anyOf)&&t.set(c,f)}}}return t}function ce(e,n,t,r,s){let i=pe(n,t);if(i.size>0){e.push("// Generated Request Types"),e.push("");for(let[o,p]of i){let a=z(o,p,new Set,s,r);e.push(a),e.push(""),e.push(`export type ${o} = z.infer<typeof ${o}>;`),e.push("")}}}function fe(e,n,t,r,s){let i=ue(n,t);if(i.size>0){e.push("// Generated Response Types"),e.push("");for(let[o,p]of i){let a=z(o,p,new Set,s,r);e.push(a),e.push(""),e.push(`export type ${o} = z.infer<typeof ${o}>;`),e.push("")}}}function de(){let e=[];return e.push("// Generated helper types for Zenko"),e.push("// This file provides type definitions for operation objects and path functions"),e.push(""),e.push("export type PathFn<TArgs extends unknown[] = []> = (...args: TArgs) => string"),e.push(""),e.push('export type RequestMethod = "get" | "put" | "post" | "delete" | "options" | "head" | "patch" | "trace"'),e.push(""),e.push("export type HeaderFn<TArgs extends unknown[] = [], TResult = Record<string, unknown> | Record<string, never>> = (...args: TArgs) => TResult"),e.push(""),e.push("export type AnyHeaderFn = HeaderFn<any, unknown> | (() => unknown)"),e.push(""),e.push("export type OperationErrors<TError = unknown> = TError extends Record<string, unknown> ? TError : Record<string, TError>;"),e.push(""),e.push("export type OperationDefinition<TMethod extends RequestMethod, TPath extends (...args: any[]) => string, TRequest = undefined, TResponse = undefined, THeaders extends AnyHeaderFn | undefined = undefined, TErrors extends OperationErrors | undefined = undefined> = {"),e.push(" method: TMethod"),e.push(" path: TPath"),e.push(" request?: TRequest"),e.push(" response?: TResponse"),e.push(" headers?: THeaders"),e.push(" errors?: TErrors"),e.push("}"),e.push(""),e.join(`
|
|
8
|
+
`)}function Ne(e){return e===void 0?{open:!1,prefix:"Unknown:"}:typeof e=="boolean"?{open:e,prefix:"Unknown:"}:Array.isArray(e)?{open:e,prefix:"Unknown:"}:{open:e.open??!1,prefix:e.unknownPrefix??"Unknown:"}}function je(e,n={}){let t=[],r=new Set,{strictDates:s=!1,strictNumeric:i=!1,operationIds:o,openEnums:p=!1}=n,a=Ce(n.types),y=Ne(p),h={strictDates:s,strictNumeric:i,optionalType:a.optionalType,openEnums:y.open,openEnumPrefix:y.prefix};t.push('import { z } from "zod";');let f=new Map;if(e.components?.schemas)for(let u of Object.keys(e.components.schemas))f.set(u,O(u));let c=ae(e,f);if(o&&o.length>0){let u=new Set(o);c=c.filter(m=>u.has(m.operationId))}if(He(t,a,c),t.push(""),e.components?.schemas){t.push("// Generated Zod Schemas"),t.push("");let u;if(o&&o.length>0){let T=J(c,e);u=Array.from(T)}else u=Object.keys(e.components.schemas);let m=V(e.components.schemas).filter(T=>u.includes(T));for(let T of m){let R=e.components.schemas[T],P=f.get(T);t.push(z(P,R,r,h,f)),t.push(""),t.push(`export type ${P} = z.infer<typeof ${P}>;`),t.push("")}}t.push("// Path Functions"),t.push("export const paths = {");for(let u of c){let T=u.pathParams.map(d=>d.name).length>0,R=u.queryParams.length>0,P=O(u.operationId);if(!T&&!R){t.push(` ${l(P)}: () => "${u.path}",`);continue}let k=d=>{if(I(d))return d;let x=O(d);return I(x)||(x=`_${x}`),x},E=[],C=[];for(let d of u.pathParams)E.push(I(d.name)?d.name:`${l(d.name)}: ${k(d.name)}`),C.push(`${l(d.name)}: string`);for(let d of u.queryParams)E.push(I(d.name)?d.name:`${l(d.name)}: ${k(d.name)}`),C.push(`${l(d.name)}${d.required?"":"?"}: ${Be(d)}`);let Te=!T&&R&&u.queryParams.every(d=>!d.required),_=`${E.length?`{ ${E.join(", ")} }`:"{}"}: { ${C.join(", ")} }${Te?" = {}":""}`,L=u.path.replace(/{([^}]+)}/g,(d,x)=>`\${${k(x)}}`);if(!R){t.push(` ${l(P)}: (${_}) => \`${L}\`,`);continue}t.push(` ${l(P)}: (${_}) => {`),t.push(" const params = new URLSearchParams()");for(let d of u.queryParams){let x=I(d.name)?d.name:k(O(d.name)),H=d.schema??{};if(H?.type==="array"){let Q=le(H.items??{},"value");d.required?(t.push(` for (const value of ${x}) {`),t.push(` params.append("${d.name}", ${Q})`),t.push(" }")):(t.push(` if (${x} !== undefined) {`),t.push(` for (const value of ${x}) {`),t.push(` params.append("${d.name}", ${Q})`),t.push(" }"),t.push(" }"));continue}let U=le(H,x);d.required?t.push(` params.set("${d.name}", ${U})`):(t.push(` if (${x} !== undefined) {`),t.push(` params.set("${d.name}", ${U})`),t.push(" }"))}t.push(" const _searchParams = params.toString()"),t.push(` return \`${L}\${_searchParams ? \`?\${_searchParams}\` : ""}\``),t.push(" },")}t.push("} as const;"),t.push(""),t.push("// Header Schemas"),t.push("export const headerSchemas = {");for(let u of c){let m=O(u.operationId);if(!u.requestHeaders||u.requestHeaders.length===0){t.push(` ${l(m)}: z.object({}),`);continue}let T=u.requestHeaders.map(R=>{let P=Ze(R),k=R.required?P:D(P,h.optionalType);return` ${l(R.name)}: ${k},`}).join(`
|
|
9
|
+
`);t.push(` ${l(m)}: z.object({`),t.push(T),t.push(" }),")}t.push("} as const;"),t.push(""),t.push("// Header Functions"),t.push("export const headers = {");for(let u of c){let m=O(u.operationId);if(!u.requestHeaders||u.requestHeaders.length===0){t.push(` ${l(m)}: () => ${I(m)?`headerSchemas.${m}`:`headerSchemas[${l(m)}]`}.parse({}),`);continue}t.push(` ${l(m)}: (params: z.input<${I(m)?`typeof headerSchemas.${m}`:`(typeof headerSchemas)[${l(m)}]`}>) => {`),t.push(` return ${I(m)?`headerSchemas.${m}`:`headerSchemas[${l(m)}]`}.parse(params)`),t.push(" },")}t.push("} as const;"),t.push(""),ce(t,c,e,f,h),fe(t,c,e,f,h),Fe(t,c,a),t.push("// Operation Objects");for(let u of c){let m=O(u.operationId),T=a.emit?`: ${b(m)}Operation`:"";t.push(`export const ${m}${T} = {`),t.push(` method: "${u.method}",`),t.push(` path: paths.${m},`),me(t,"request",u.requestType),me(t,"response",u.responseType),u.requestHeaders&&u.requestHeaders.length>0&&t.push(` headers: headers.${m},`),u.errors&&he(u.errors)&&Me(t,"errors",u.errors),t.push("} as const;"),t.push("")}let $={output:t.join(`
|
|
10
|
+
`)};return a.emit&&a.helpers==="file"&&a.helpersOutput&&($.helperFile={path:a.helpersOutput,content:de()}),$}function Mt(e,n={}){return je(e,n).output}function me(e,n,t){t&&e.push(` ${n}: ${t},`)}function Me(e,n,t){if(!(!t||Object.keys(t).length===0)){e.push(` ${n}: {`);for(let[r,s]of Object.entries(t))e.push(` ${l(r)}: ${s},`);e.push(" },")}}function he(e){return!!(e&&Object.keys(e).length>0)}function Ce(e){return{emit:e?.emit??!0,helpers:e?.helpers??"package",helpersOutput:e?.helpersOutput??"./zenko-types",treeShake:e?.treeShake??!0,optionalType:e?.optionalType??"optional"}}function He(e,n,t){if(n.emit)switch(n.helpers){case"package":if(n.treeShake){let r=F(t),s=G(r,"package");s&&e.push(s)}else e.push('import type { PathFn, HeaderFn, OperationDefinition, OperationErrors } from "zenko";');return;case"file":if(n.treeShake){let r=F(t),s=G(r,"file",n.helpersOutput);s&&e.push(s)}else e.push(`import type { PathFn, HeaderFn, OperationDefinition, OperationErrors } from "${n.helpersOutput}";`);return;case"inline":e.push("type PathFn<TArgs extends unknown[] = []> = (...args: TArgs) => string;"),e.push('type RequestMethod = "get" | "put" | "post" | "delete" | "options" | "head" | "patch" | "trace";'),e.push("type HeaderFn<TArgs extends unknown[] = [], TResult = Record<string, unknown> | Record<string, never>> = (...args: TArgs) => TResult;"),e.push("type AnyHeaderFn = HeaderFn<any, unknown> | (() => unknown);"),e.push("type OperationErrors<TError = unknown> = TError extends Record<string, unknown> ? TError : Record<string, TError>;"),e.push("type OperationDefinition<TMethod extends RequestMethod, TPath extends (...args: any[]) => string, TRequest = undefined, TResponse = undefined, THeaders extends AnyHeaderFn | undefined = undefined, TErrors extends OperationErrors | undefined = undefined> = {"),e.push(" method: TMethod"),e.push(" path: TPath"),e.push(" request?: TRequest"),e.push(" response?: TResponse"),e.push(" headers?: THeaders"),e.push(" errors?: TErrors"),e.push("}"),e.push("")}}function Fe(e,n,t){if(t.emit){e.push("// Operation Types");for(let r of n){let s=O(r.operationId),i=r.requestHeaders?.length?I(s)?`typeof headers.${s}`:`(typeof headers)[${l(s)}]`:"undefined",o=B(r.requestType),p=B(r.responseType),a=Ge(r.errors);e.push(`export type ${b(s)}Operation = OperationDefinition<`),e.push(` "${r.method}",`),e.push(` ${I(s)?`typeof paths.${s}`:`(typeof paths)[${l(s)}]`},`),e.push(` ${o},`),e.push(` ${p},`),e.push(` ${i},`),e.push(` ${a}`),e.push(">;"),e.push("")}}}function Ge(e){return!e||!he(e)?"OperationErrors":`OperationErrors<${De(e)}>`}function De(e){return!e||Object.keys(e).length===0?"unknown":`{ ${Object.entries(e).map(([r,s])=>{let i=l(r),o=$e(s);return`${i}: ${o}`}).join("; ")} }`}var ye=new Set(["any","unknown","never","void","null","undefined","string","number","boolean","bigint","symbol"]),ge=/^[A-Za-z_$][A-Za-z0-9_$]*$/;function B(e){if(!e)return"undefined";let n=e.trim();if(n==="undefined")return"undefined";if(ye.has(n)||n.startsWith("typeof "))return n;let t=n.match(/^z\.array\((.+)\)$/);return t?`z.ZodArray<${B(t[1])}>`:ge.test(n)?`typeof ${n}`:n}function $e(e){if(!e)return"unknown";let n=e.trim();if(ye.has(n)||n.startsWith("typeof "))return n;let t=n.match(/^z\.array\((.+)\)$/);return t?`z.ZodArray<${$e(t[1])}>`:ge.test(n)?`typeof ${n}`:n}function Ze(e){let n=e.schema??{};switch(n.type){case"integer":case"number":return"z.coerce.number()";case"boolean":return"z.coerce.boolean()";case"array":{let r=n.items??{type:"string"};return`z.array(${r.type==="integer"||r.type==="number"?"z.coerce.number()":r.type==="boolean"?"z.coerce.boolean()":"z.string()"})`}default:return"z.string()"}}function Be(e){return Oe(e.schema)}function Oe(e){if(!e)return"string";if(e.type==="array")return`Array<${Oe(e.items)}>`;switch(e.type){case"integer":case"number":return"number";case"boolean":return"boolean";default:return"string"}}function le(e,n){if(!e)return`String(${n})`;switch(e.type){case"integer":case"number":return`String(${n})`;case"boolean":return`${n} ? "true" : "false"`;default:return`String(${n})`}}export{je as a,Mt as b};
|
|
11
|
+
//# sourceMappingURL=chunk-64LDA5YF.mjs.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }function Q(e){let n=new Set,t=new Set,r=[],s=i=>{if(n.has(i)||t.has(i))return;t.add(i);let o=e[i],p=A(o);for(let a of p)e[a]&&s(a);t.delete(i),n.add(i),r.push(i)};for(let i of Object.keys(e))s(i);return r}function A(e){let n=[],t=r=>{if(!(typeof r!="object"||r===null)){if(r.$ref&&typeof r.$ref=="string"){let s=g(r.$ref);n.push(s);return}Array.isArray(r)?r.forEach(t):Object.values(r).forEach(t)}};return t(e),[...new Set(n)]}function g(e){return e.split("/").pop()||"Unknown"}function w(e){if(!e)return!1;let n=e.at(0);return n===void 0||!/[a-zA-Z_$]/.test(n)||!/^[a-zA-Z_$][a-zA-Z0-9_$]*$/.test(e)?!1:!new Set(["abstract","arguments","await","boolean","break","byte","case","catch","char","class","const","continue","debugger","default","delete","do","double","else","enum","eval","export","extends","false","final","finally","float","for","function","goto","if","implements","import","in","instanceof","int","interface","let","long","native","new","null","package","private","protected","public","return","short","static","super","switch","synchronized","this","throw","throws","transient","true","try","typeof","var","void","volatile","while","with","yield","async"]).has(e)}function l(e){return w(e)?e:`"${e}"`}function O(e){return e.replace(/-([a-zA-Z])/g,(n,t)=>t.toUpperCase()).replace(/-+$/,"")}function I(e){return e.charAt(0).toUpperCase()+e.slice(1)}function H(e){let n={usesHeaderFn:!1,usesOperationDefinition:!1,usesOperationErrors:!1};e.length>0&&(n.usesOperationDefinition=!0);for(let t of e)t.errors&&V(t.errors)&&(n.usesOperationErrors=!0);return e.length>0&&!n.usesOperationErrors&&e.some(r=>!r.errors||!V(r.errors))&&(n.usesOperationErrors=!0),n}function F(e,n,t){let r=[];if(e.usesHeaderFn&&r.push("HeaderFn"),e.usesOperationDefinition&&r.push("OperationDefinition"),e.usesOperationErrors&&r.push("OperationErrors"),r.length===0)return"";let s=n==="package"?'"zenko"':`"${t}"`;return`import type { ${r.join(", ")} } from ${s};`}function V(e){return!!(e&&Object.keys(e).length>0)}var E={"application/json":"unknown","text/csv":"string","text/plain":"string","application/octet-stream":"unknown","application/pdf":"unknown"};function v(e){let n=Object.keys(e);if(n.includes("application/json"))return"application/json";for(let t of n)if(t in E)return t;return n[0]||""}function N(e,n){if(e){if(e.$ref){let t=g(e.$ref),r=_optionalChain([n, 'access', _2 => _2.components, 'optionalAccess', _3 => _3.parameters, 'optionalAccess', _4 => _4[t]]);if(!r)return;let{$ref:s,...i}=e;return{...r,...i}}return e}}function W(e,n){let t=new Set,r=new Map;for(let[,o]of Object.entries(n.paths||{}))for(let[,p]of Object.entries(o)){let a=p;a.operationId&&r.set(a.operationId,a)}for(let[,o]of Object.entries(n.webhooks||{}))for(let[,p]of Object.entries(o)){let a=p;a.operationId&&r.set(a.operationId,a)}for(let o of e){let p=r.get(o.operationId);if(!p)continue;let a=_optionalChain([p, 'access', _5 => _5.requestBody, 'optionalAccess', _6 => _6.content, 'optionalAccess', _7 => _7["application/json"], 'optionalAccess', _8 => _8.schema]);if(_optionalChain([a, 'optionalAccess', _9 => _9.$ref])){let f=g(a.$ref);t.add(f)}else if(a){let f=A(a);for(let c of f)_optionalChain([n, 'access', _10 => _10.components, 'optionalAccess', _11 => _11.schemas, 'optionalAccess', _12 => _12[c]])&&t.add(c)}let y=p.responses||{};for(let[,f]of Object.entries(y)){let c=_optionalChain([f, 'optionalAccess', _13 => _13.content]);if(!c)continue;let $=v(c),u=_optionalChain([c, 'access', _14 => _14[$], 'optionalAccess', _15 => _15.schema]);if(_optionalChain([u, 'optionalAccess', _16 => _16.$ref])){let m=g(u.$ref);t.add(m)}else if(u){let m=A(u);for(let T of m)_optionalChain([n, 'access', _17 => _17.components, 'optionalAccess', _18 => _18.schemas, 'optionalAccess', _19 => _19[T]])&&t.add(T)}}for(let f of o.queryParams){if(_optionalChain([f, 'access', _20 => _20.schema, 'optionalAccess', _21 => _21.$ref])){let c=g(f.schema.$ref);t.add(c)}if(_optionalChain([f, 'access', _22 => _22.schema, 'optionalAccess', _23 => _23.items, 'optionalAccess', _24 => _24.$ref])){let c=g(f.schema.items.$ref);t.add(c)}}for(let f of o.requestHeaders||[]){if(_optionalChain([f, 'access', _25 => _25.schema, 'optionalAccess', _26 => _26.$ref])){let c=g(f.schema.$ref);t.add(c)}if(_optionalChain([f, 'access', _27 => _27.schema, 'optionalAccess', _28 => _28.items, 'optionalAccess', _29 => _29.$ref])){let c=g(f.schema.items.$ref);t.add(c)}}let h=p.parameters||[];for(let f of h){let c=N(f,n);if(_optionalChain([c, 'optionalAccess', _30 => _30.schema, 'optionalAccess', _31 => _31.$ref])){let $=g(c.schema.$ref);t.add($)}if(_optionalChain([c, 'optionalAccess', _32 => _32.schema, 'optionalAccess', _33 => _33.items, 'optionalAccess', _34 => _34.$ref])){let $=g(c.schema.items.$ref);t.add($)}}}let s=new Set,i=Array.from(t);for(;i.length>0;){let o=i.pop();if(s.has(o))continue;s.add(o);let p=_optionalChain([n, 'access', _35 => _35.components, 'optionalAccess', _36 => _36.schemas, 'optionalAccess', _37 => _37[o]]);if(!p)continue;let a=A(p);for(let y of a)_optionalChain([n, 'access', _38 => _38.components, 'optionalAccess', _39 => _39.schemas, 'optionalAccess', _40 => _40[y]])&&!s.has(y)&&(t.add(y),i.push(y))}return t}function Te(e,n){return n===!0?!0:Array.isArray(n)?n.includes(e):!1}function G(e,n){switch(n){case"optional":return`${e}.optional()`;case"nullable":return`${e}.nullable()`;case"nullish":return`${e}.nullish()`}}function q(e,n,t,r,s){if(t.has(e))return"";if(t.add(e),n.enum){let i=n.enum.map(o=>`"${o}"`).join(", ");if(Te(e,r.openEnums)){let o=r.openEnumPrefix;return`const ${e}Known = [${i}] as const;
|
|
2
|
+
export const ${e} = z.enum(${e}Known).or(
|
|
3
|
+
z.string().transform((v): \`${o}\${string}\` => \`${o}\${v}\`)
|
|
4
|
+
);`}return`export const ${e} = z.enum([${i}]);`}if(n.allOf&&Array.isArray(n.allOf)){let i=n.allOf.map(a=>k(a,r,s));if(i.length===0)return`export const ${e} = z.object({});`;if(i.length===1)return`export const ${e} = ${i[0]};`;let o=i[0],p=i.slice(1).map(a=>`.and(${a})`).join("");return`export const ${e} = ${o}${p};`}if(n.type==="object"||n.properties)return`export const ${e} = ${J(n,r,s)};`;if(n.type==="array"){let i=_nullishCoalesce(n.items, () => ({type:"unknown"})),o=k(i,r,s),p=Ie(n,`z.array(${o})`,i,r.strictNumeric);return`export const ${e} = ${p};`}return`export const ${e} = ${k(n,r,s)};`}function k(e,n,t){if(e.$ref){let r=g(e.$ref);return _optionalChain([t, 'optionalAccess', _41 => _41.get, 'call', _42 => _42(r)])||r}if(e.enum)return`z.enum([${e.enum.map(s=>`"${s}"`).join(", ")}])`;if(e.allOf&&Array.isArray(e.allOf)){let r=e.allOf.map(o=>k(o,n,t));if(r.length===0)return"z.object({})";if(r.length===1)return r[0];let s=r[0],i=r.slice(1).map(o=>`.and(${o})`).join("");return`${s}${i}`}if(e.type==="object"||e.properties||e.allOf||e.oneOf||e.anyOf)return J(e,n,t);switch(e.type){case"string":return xe(e,n);case"boolean":return"z.boolean()";case"array":return`z.array(${k(_nullishCoalesce(e.items, () => ({type:"unknown"})),n,t)})`;case"null":return"z.null()";case"number":return K(e,n);case"integer":return we(e,n);default:return"z.unknown()"}}function J(e,n,t){let r=[];for(let[s,i]of Object.entries(e.properties||{})){let o=_nullishCoalesce(_optionalChain([e, 'access', _43 => _43.required, 'optionalAccess', _44 => _44.includes, 'call', _45 => _45(s)]), () => (!1)),p=k(i,n,t),a=G(p,n.optionalType),y=n.optionalType!=="nullable"?Se(a,i):a,h=o?p:y;r.push(` ${l(s)}: ${h},`)}return r.length===0?"z.object({})":`z.object({
|
|
5
|
+
${r.join(`
|
|
6
|
+
`)}
|
|
7
|
+
})`}function xe(e,n){if(e.format==="binary")return'(typeof Blob === "undefined" ? z.unknown() : z.instanceof(Blob))';if(n.strictDates)switch(e.format){case"date-time":return"z.string().datetime()";case"date":return"z.string().date()";case"time":return"z.string().time()";case"duration":return"z.string().duration()"}let t="z.string()";switch(n.strictNumeric&&(typeof e.minLength=="number"&&(t+=`.min(${e.minLength})`),typeof e.maxLength=="number"&&(t+=`.max(${e.maxLength})`),e.pattern&&(t+=`.regex(new RegExp(${JSON.stringify(e.pattern)}))`)),e.format){case"uuid":return`${t}.uuid()`;case"email":return`${t}.email()`;case"uri":case"url":return`${t}.url()`;case"ipv4":return`${t}.ip({ version: "v4" })`;case"ipv6":return`${t}.ip({ version: "v6" })`;default:return t}}function Se(e,n){return!n||n.default===void 0?e:`${e}.default(${JSON.stringify(n.default)})`}function K(e,n){let t="z.number()";return n.strictNumeric&&(t=Pe(e,t),typeof e.multipleOf=="number"&&e.multipleOf!==0&&(t+=`.refine((value) => Math.abs(value / ${e.multipleOf} - Math.round(value / ${e.multipleOf})) < Number.EPSILON, { message: "Must be a multiple of ${e.multipleOf}" })`)),t}function we(e,n){let t=K(e,n);return t+=".int()",t}function Ie(e,n,t,r){return r&&(typeof e.minItems=="number"&&(n+=`.min(${e.minItems})`),typeof e.maxItems=="number"&&(n+=`.max(${e.maxItems})`),e.uniqueItems&&be(t)&&(n+='.refine((items) => new Set(items).size === items.length, { message: "Items must be unique" })')),n}function be(e){return _optionalChain([e, 'optionalAccess', _46 => _46.$ref])?!1:new Set(["string","number","integer","boolean"]).has(_optionalChain([e, 'optionalAccess', _47 => _47.type]))}function Pe(e,n){return typeof e.minimum=="number"?e.exclusiveMinimum===!0?n+=`.gt(${e.minimum})`:n+=`.min(${e.minimum})`:typeof e.exclusiveMinimum=="number"&&(n+=`.gt(${e.exclusiveMinimum})`),typeof e.maximum=="number"?e.exclusiveMaximum===!0?n+=`.lt(${e.maximum})`:n+=`.max(${e.maximum})`:typeof e.exclusiveMaximum=="number"&&(n+=`.lt(${e.exclusiveMaximum})`),n}var Re={400:"badRequest",401:"unauthorized",402:"paymentRequired",403:"forbidden",404:"notFound",405:"methodNotAllowed",406:"notAcceptable",407:"proxyAuthenticationRequired",408:"requestTimeout",409:"conflict",410:"gone",411:"lengthRequired",412:"preconditionFailed",413:"payloadTooLarge",414:"uriTooLong",415:"unsupportedMediaType",416:"rangeNotSatisfiable",417:"expectationFailed",418:"imATeapot",421:"misdirectedRequest",422:"unprocessableEntity",423:"locked",424:"failedDependency",425:"tooEarly",426:"upgradeRequired",428:"preconditionRequired",429:"tooManyRequests",431:"requestHeaderFieldsTooLarge",451:"unavailableForLegalReasons",500:"internalServerError",501:"notImplemented",502:"badGateway",503:"serviceUnavailable",504:"gatewayTimeout",505:"httpVersionNotSupported",506:"variantAlsoNegotiates",507:"insufficientStorage",508:"loopDetected",510:"notExtended",511:"networkAuthenticationRequired"};function Y(e){if(e==="default")return"defaultError";let n=e.trim(),t=Re[n];if(t)return t;if(/^\d{3}$/.test(n))return`status${n}`;let r=n.toLowerCase().replace(/[^a-z0-9]+/g," ").trim();if(!r)return"unknownError";let s=r.split(/\s+/),[i,...o]=s,p=i+o.map(a=>a.charAt(0).toUpperCase()+a.slice(1)).join("");return p?/^[a-zA-Z_$]/.test(p)?p:`status${p.charAt(0).toUpperCase()}${p.slice(1)}`:"unknownError"}function j(e){if(e==="default")return!0;let n=Number(e);return Number.isInteger(n)?n>=400:!1}function ie(e,n){let t=[];if(e.paths)for(let[r,s]of Object.entries(e.paths))for(let[i,o]of Object.entries(s)){let p=i.toLowerCase();if(!se(p)||!o.operationId)continue;let a=ee(r),y=te(o,n),{successResponse:h,errors:f}=ne(o,o.operationId,n),c=X(s,o,e),$=re(c),u=oe(c);t.push({operationId:o.operationId,path:r,method:p,pathParams:a,queryParams:u,requestType:y,responseType:h,requestHeaders:$,errors:f})}if(e.webhooks)for(let[r,s]of Object.entries(e.webhooks))for(let[i,o]of Object.entries(s)){let p=i.toLowerCase();if(!se(p)||!o.operationId)continue;let a=r,y=ee(a),h=te(o,n),{successResponse:f,errors:c}=ne(o,o.operationId,n),$=X(s,o,e),u=re($),m=oe($);t.push({operationId:o.operationId,path:a,method:p,pathParams:y,queryParams:m,requestType:h,responseType:f,requestHeaders:u,errors:c})}return t}function X(e,n,t){let r=new Map,s=i=>{if(Array.isArray(i))for(let o of i){let p=N(o,t);if(!p)continue;let a=`${p.in}:${p.name}`;r.set(a,p)}};return s(e.parameters),s(n.parameters),Array.from(r.values())}function ee(e){let n=[],t=e.match(/{([^}]+)}/g);if(t)for(let r of t){let s=r.slice(1,-1);n.push({name:s,type:"string"})}return n}function te(e,n){let t=ke(e);if(!t)return;if(t.$ref){let s=g(t.$ref);return _optionalChain([n, 'optionalAccess', _48 => _48.get, 'call', _49 => _49(s)])||s}return`${I(O(e.operationId))}Request`}function ke(e){let n=_optionalChain([e, 'optionalAccess', _50 => _50.requestBody, 'optionalAccess', _51 => _51.content]);if(!n||Object.keys(n).length===0)return;let t=["application/json","multipart/form-data","application/x-www-form-urlencoded"];for(let r of t){let s=_optionalChain([n, 'access', _52 => _52[r], 'optionalAccess', _53 => _53.schema]);if(s)return s}}function ne(e,n,t){let r=_nullishCoalesce(e.responses, () => ({})),s=new Map,i=[];for(let[a,y]of Object.entries(r)){let h=_optionalChain([y, 'optionalAccess', _54 => _54.content]);if(!h||Object.keys(h).length===0){a==="204"||/^3\d\d$/.test(a)?s.set(a,"undefined"):j(a)&&i.push({code:a,schema:"undefined"});continue}let f=v(h),c=_optionalChain([h, 'access', _55 => _55[f], 'optionalAccess', _56 => _56.schema]);if(!c){let $=ze(f,a);$&&(j(a)?i.push({code:a,schema:$}):/^2\d\d$/.test(a)&&s.set(a,$));continue}if(j(a)){i.push({code:a,schema:c});continue}/^2\d\d$/.test(a)&&s.set(a,c)}let o=Ae(s,n,t),p=qe(i,n,t);return{successResponse:o,errors:p}}function Ae(e,n,t){if(e.size===0)return;let r=["200","201","204"];for(let i of r){let o=e.get(i);if(o)return typeof o=="string"?o:D(o,`${I(O(n))}Response`,t)}let[,s]=_nullishCoalesce(e.entries().next().value, () => ([]));if(s)return typeof s=="string"?s:D(s,`${I(O(n))}Response`,t)}function qe(e=[],n,t){if(!e.length)return;let r={};for(let{code:s,schema:i}of e){let o=Y(s),p=D(i,`${I(O(n))}${I(o)}`,t);r[o]=p}return r}function D(e,n,t){if(typeof e=="string")return e;if(e.$ref){let r=g(e.$ref);return _optionalChain([t, 'optionalAccess', _57 => _57.get, 'call', _58 => _58(r)])||r}if(e.type==="array"&&_optionalChain([e, 'access', _59 => _59.items, 'optionalAccess', _60 => _60.$ref])){let r=g(e.items.$ref);return`z.array(${_optionalChain([t, 'optionalAccess', _61 => _61.get, 'call', _62 => _62(r)])||r})`}return e.allOf&&Array.isArray(e.allOf),n}function re(e){let n=[];for(let t of _nullishCoalesce(e, () => ([])))t.in==="header"&&n.push({name:t.name,description:t.description,schema:t.schema,required:t.required});return n}function oe(e){let n=[];for(let t of _nullishCoalesce(e, () => ([])))t.in==="query"&&n.push({name:t.name,description:t.description,schema:t.schema,required:t.required});return n}function se(e){switch(e){case"get":case"put":case"post":case"delete":case"options":case"head":case"patch":case"trace":return!0;default:return!1}}function ze(e,n){return n==="204"||/^3\d\d$/.test(n)?"undefined":e in E?E[e]:"unknown"}function ae(e,n){let t=new Map,r=new Map;for(let[,s]of Object.entries(n.paths||{}))for(let[,i]of Object.entries(s)){let o=i;o.operationId&&r.set(o.operationId,o)}for(let[,s]of Object.entries(n.webhooks||{}))for(let[,i]of Object.entries(s)){let o=i;o.operationId&&r.set(o.operationId,o)}for(let s of e){let i=r.get(s.operationId);if(!i)continue;let o=i.requestBody;if(o&&o.content){let p=o.content,a=Ee(p);if(!a)continue;let y=`${I(O(s.operationId))}Request`;(!a.$ref||a.allOf||a.oneOf||a.anyOf)&&t.set(y,a)}}return t}function Ee(e){let n=["application/json","multipart/form-data","application/x-www-form-urlencoded"];for(let t of n){let r=_optionalChain([e, 'access', _63 => _63[t], 'optionalAccess', _64 => _64.schema]);if(r)return r}}function pe(e,n){let t=new Map,r=new Map;for(let[,s]of Object.entries(n.paths||{}))for(let[,i]of Object.entries(s)){let o=i;o.operationId&&r.set(o.operationId,o)}for(let[,s]of Object.entries(n.webhooks||{}))for(let[,i]of Object.entries(s)){let o=i;o.operationId&&r.set(o.operationId,o)}for(let s of e){let i=r.get(s.operationId);if(!i)continue;let o=i.responses||{};for(let[p,a]of Object.entries(o))if(/^2\d\d$/.test(p)&&a.content){let h=a.content["application/json"];if(h&&h.schema){let f=h.schema,c=`${I(O(s.operationId))}Response`;(!f.$ref||f.allOf||f.oneOf||f.anyOf)&&t.set(c,f)}}}return t}function ue(e,n,t,r,s){let i=ae(n,t);if(i.size>0){e.push("// Generated Request Types"),e.push("");for(let[o,p]of i){let a=q(o,p,new Set,s,r);e.push(a),e.push(""),e.push(`export type ${o} = z.infer<typeof ${o}>;`),e.push("")}}}function ce(e,n,t,r,s){let i=pe(n,t);if(i.size>0){e.push("// Generated Response Types"),e.push("");for(let[o,p]of i){let a=q(o,p,new Set,s,r);e.push(a),e.push(""),e.push(`export type ${o} = z.infer<typeof ${o}>;`),e.push("")}}}function fe(){let e=[];return e.push("// Generated helper types for Zenko"),e.push("// This file provides type definitions for operation objects and path functions"),e.push(""),e.push("export type PathFn<TArgs extends unknown[] = []> = (...args: TArgs) => string"),e.push(""),e.push('export type RequestMethod = "get" | "put" | "post" | "delete" | "options" | "head" | "patch" | "trace"'),e.push(""),e.push("export type HeaderFn<TArgs extends unknown[] = [], TResult = Record<string, unknown> | Record<string, never>> = (...args: TArgs) => TResult"),e.push(""),e.push("export type AnyHeaderFn = HeaderFn<any, unknown> | (() => unknown)"),e.push(""),e.push("export type OperationErrors<TError = unknown> = TError extends Record<string, unknown> ? TError : Record<string, TError>;"),e.push(""),e.push("export type OperationDefinition<TMethod extends RequestMethod, TPath extends (...args: any[]) => string, TRequest = undefined, TResponse = undefined, THeaders extends AnyHeaderFn | undefined = undefined, TErrors extends OperationErrors | undefined = undefined> = {"),e.push(" method: TMethod"),e.push(" path: TPath"),e.push(" request?: TRequest"),e.push(" response?: TResponse"),e.push(" headers?: THeaders"),e.push(" errors?: TErrors"),e.push("}"),e.push(""),e.join(`
|
|
8
|
+
`)}function ve(e){return e===void 0?{open:!1,prefix:"Unknown:"}:typeof e=="boolean"?{open:e,prefix:"Unknown:"}:Array.isArray(e)?{open:e,prefix:"Unknown:"}:{open:_nullishCoalesce(e.open, () => (!1)),prefix:_nullishCoalesce(e.unknownPrefix, () => ("Unknown:"))}}function Ne(e,n={}){let t=[],r=new Set,{strictDates:s=!1,strictNumeric:i=!1,operationIds:o,openEnums:p=!1}=n,a=Me(n.types),y=ve(p),h={strictDates:s,strictNumeric:i,optionalType:a.optionalType,openEnums:y.open,openEnumPrefix:y.prefix};t.push('import { z } from "zod";');let f=new Map;if(_optionalChain([e, 'access', _65 => _65.components, 'optionalAccess', _66 => _66.schemas]))for(let u of Object.keys(e.components.schemas))f.set(u,O(u));let c=ie(e,f);if(o&&o.length>0){let u=new Set(o);c=c.filter(m=>u.has(m.operationId))}if(Ce(t,a,c),t.push(""),_optionalChain([e, 'access', _67 => _67.components, 'optionalAccess', _68 => _68.schemas])){t.push("// Generated Zod Schemas"),t.push("");let u;if(o&&o.length>0){let T=W(c,e);u=Array.from(T)}else u=Object.keys(e.components.schemas);let m=Q(e.components.schemas).filter(T=>u.includes(T));for(let T of m){let P=e.components.schemas[T],b=f.get(T);t.push(q(b,P,r,h,f)),t.push(""),t.push(`export type ${b} = z.infer<typeof ${b}>;`),t.push("")}}t.push("// Path Functions"),t.push("export const paths = {");for(let u of c){let T=u.pathParams.map(d=>d.name).length>0,P=u.queryParams.length>0,b=O(u.operationId);if(!T&&!P){t.push(` ${l(b)}: () => "${u.path}",`);continue}let R=d=>{if(w(d))return d;let x=O(d);return w(x)||(x=`_${x}`),x},z=[],M=[];for(let d of u.pathParams)z.push(w(d.name)?d.name:`${l(d.name)}: ${R(d.name)}`),M.push(`${l(d.name)}: string`);for(let d of u.queryParams)z.push(w(d.name)?d.name:`${l(d.name)}: ${R(d.name)}`),M.push(`${l(d.name)}${d.required?"":"?"}: ${Ze(d)}`);let Oe=!T&&P&&u.queryParams.every(d=>!d.required),B=`${z.length?`{ ${z.join(", ")} }`:"{}"}: { ${M.join(", ")} }${Oe?" = {}":""}`,_=u.path.replace(/{([^}]+)}/g,(d,x)=>`\${${R(x)}}`);if(!P){t.push(` ${l(b)}: (${B}) => \`${_}\`,`);continue}t.push(` ${l(b)}: (${B}) => {`),t.push(" const params = new URLSearchParams()");for(let d of u.queryParams){let x=w(d.name)?d.name:R(O(d.name)),C=_nullishCoalesce(d.schema, () => ({}));if(_optionalChain([C, 'optionalAccess', _69 => _69.type])==="array"){let U=me(_nullishCoalesce(C.items, () => ({})),"value");d.required?(t.push(` for (const value of ${x}) {`),t.push(` params.append("${d.name}", ${U})`),t.push(" }")):(t.push(` if (${x} !== undefined) {`),t.push(` for (const value of ${x}) {`),t.push(` params.append("${d.name}", ${U})`),t.push(" }"),t.push(" }"));continue}let L=me(C,x);d.required?t.push(` params.set("${d.name}", ${L})`):(t.push(` if (${x} !== undefined) {`),t.push(` params.set("${d.name}", ${L})`),t.push(" }"))}t.push(" const _searchParams = params.toString()"),t.push(` return \`${_}\${_searchParams ? \`?\${_searchParams}\` : ""}\``),t.push(" },")}t.push("} as const;"),t.push(""),t.push("// Header Schemas"),t.push("export const headerSchemas = {");for(let u of c){let m=O(u.operationId);if(!u.requestHeaders||u.requestHeaders.length===0){t.push(` ${l(m)}: z.object({}),`);continue}let T=u.requestHeaders.map(P=>{let b=De(P),R=P.required?b:G(b,h.optionalType);return` ${l(P.name)}: ${R},`}).join(`
|
|
9
|
+
`);t.push(` ${l(m)}: z.object({`),t.push(T),t.push(" }),")}t.push("} as const;"),t.push(""),t.push("// Header Functions"),t.push("export const headers = {");for(let u of c){let m=O(u.operationId);if(!u.requestHeaders||u.requestHeaders.length===0){t.push(` ${l(m)}: () => ${w(m)?`headerSchemas.${m}`:`headerSchemas[${l(m)}]`}.parse({}),`);continue}t.push(` ${l(m)}: (params: z.input<${w(m)?`typeof headerSchemas.${m}`:`(typeof headerSchemas)[${l(m)}]`}>) => {`),t.push(` return ${w(m)?`headerSchemas.${m}`:`headerSchemas[${l(m)}]`}.parse(params)`),t.push(" },")}t.push("} as const;"),t.push(""),ue(t,c,e,f,h),ce(t,c,e,f,h),He(t,c,a),t.push("// Operation Objects");for(let u of c){let m=O(u.operationId),T=a.emit?`: ${I(m)}Operation`:"";t.push(`export const ${m}${T} = {`),t.push(` method: "${u.method}",`),t.push(` path: paths.${m},`),de(t,"request",u.requestType),de(t,"response",u.responseType),u.requestHeaders&&u.requestHeaders.length>0&&t.push(` headers: headers.${m},`),u.errors&&le(u.errors)&&je(t,"errors",u.errors),t.push("} as const;"),t.push("")}let $={output:t.join(`
|
|
10
|
+
`)};return a.emit&&a.helpers==="file"&&a.helpersOutput&&($.helperFile={path:a.helpersOutput,content:fe()}),$}function jt(e,n={}){return Ne(e,n).output}function de(e,n,t){t&&e.push(` ${n}: ${t},`)}function je(e,n,t){if(!(!t||Object.keys(t).length===0)){e.push(` ${n}: {`);for(let[r,s]of Object.entries(t))e.push(` ${l(r)}: ${s},`);e.push(" },")}}function le(e){return!!(e&&Object.keys(e).length>0)}function Me(e){return{emit:_nullishCoalesce(_optionalChain([e, 'optionalAccess', _70 => _70.emit]), () => (!0)),helpers:_nullishCoalesce(_optionalChain([e, 'optionalAccess', _71 => _71.helpers]), () => ("package")),helpersOutput:_nullishCoalesce(_optionalChain([e, 'optionalAccess', _72 => _72.helpersOutput]), () => ("./zenko-types")),treeShake:_nullishCoalesce(_optionalChain([e, 'optionalAccess', _73 => _73.treeShake]), () => (!0)),optionalType:_nullishCoalesce(_optionalChain([e, 'optionalAccess', _74 => _74.optionalType]), () => ("optional"))}}function Ce(e,n,t){if(n.emit)switch(n.helpers){case"package":if(n.treeShake){let r=H(t),s=F(r,"package");s&&e.push(s)}else e.push('import type { PathFn, HeaderFn, OperationDefinition, OperationErrors } from "zenko";');return;case"file":if(n.treeShake){let r=H(t),s=F(r,"file",n.helpersOutput);s&&e.push(s)}else e.push(`import type { PathFn, HeaderFn, OperationDefinition, OperationErrors } from "${n.helpersOutput}";`);return;case"inline":e.push("type PathFn<TArgs extends unknown[] = []> = (...args: TArgs) => string;"),e.push('type RequestMethod = "get" | "put" | "post" | "delete" | "options" | "head" | "patch" | "trace";'),e.push("type HeaderFn<TArgs extends unknown[] = [], TResult = Record<string, unknown> | Record<string, never>> = (...args: TArgs) => TResult;"),e.push("type AnyHeaderFn = HeaderFn<any, unknown> | (() => unknown);"),e.push("type OperationErrors<TError = unknown> = TError extends Record<string, unknown> ? TError : Record<string, TError>;"),e.push("type OperationDefinition<TMethod extends RequestMethod, TPath extends (...args: any[]) => string, TRequest = undefined, TResponse = undefined, THeaders extends AnyHeaderFn | undefined = undefined, TErrors extends OperationErrors | undefined = undefined> = {"),e.push(" method: TMethod"),e.push(" path: TPath"),e.push(" request?: TRequest"),e.push(" response?: TResponse"),e.push(" headers?: THeaders"),e.push(" errors?: TErrors"),e.push("}"),e.push("")}}function He(e,n,t){if(t.emit){e.push("// Operation Types");for(let r of n){let s=O(r.operationId),i=_optionalChain([r, 'access', _75 => _75.requestHeaders, 'optionalAccess', _76 => _76.length])?w(s)?`typeof headers.${s}`:`(typeof headers)[${l(s)}]`:"undefined",o=Z(r.requestType),p=Z(r.responseType),a=Fe(r.errors);e.push(`export type ${I(s)}Operation = OperationDefinition<`),e.push(` "${r.method}",`),e.push(` ${w(s)?`typeof paths.${s}`:`(typeof paths)[${l(s)}]`},`),e.push(` ${o},`),e.push(` ${p},`),e.push(` ${i},`),e.push(` ${a}`),e.push(">;"),e.push("")}}}function Fe(e){return!e||!le(e)?"OperationErrors":`OperationErrors<${Ge(e)}>`}function Ge(e){return!e||Object.keys(e).length===0?"unknown":`{ ${Object.entries(e).map(([r,s])=>{let i=l(r),o=ge(s);return`${i}: ${o}`}).join("; ")} }`}var he=new Set(["any","unknown","never","void","null","undefined","string","number","boolean","bigint","symbol"]),ye=/^[A-Za-z_$][A-Za-z0-9_$]*$/;function Z(e){if(!e)return"undefined";let n=e.trim();if(n==="undefined")return"undefined";if(he.has(n)||n.startsWith("typeof "))return n;let t=n.match(/^z\.array\((.+)\)$/);return t?`z.ZodArray<${Z(t[1])}>`:ye.test(n)?`typeof ${n}`:n}function ge(e){if(!e)return"unknown";let n=e.trim();if(he.has(n)||n.startsWith("typeof "))return n;let t=n.match(/^z\.array\((.+)\)$/);return t?`z.ZodArray<${ge(t[1])}>`:ye.test(n)?`typeof ${n}`:n}function De(e){let n=_nullishCoalesce(e.schema, () => ({}));switch(n.type){case"integer":case"number":return"z.coerce.number()";case"boolean":return"z.coerce.boolean()";case"array":{let r=_nullishCoalesce(n.items, () => ({type:"string"}));return`z.array(${r.type==="integer"||r.type==="number"?"z.coerce.number()":r.type==="boolean"?"z.coerce.boolean()":"z.string()"})`}default:return"z.string()"}}function Ze(e){return $e(e.schema)}function $e(e){if(!e)return"string";if(e.type==="array")return`Array<${$e(e.items)}>`;switch(e.type){case"integer":case"number":return"number";case"boolean":return"boolean";default:return"string"}}function me(e,n){if(!e)return`String(${n})`;switch(e.type){case"integer":case"number":return`String(${n})`;case"boolean":return`${n} ? "true" : "false"`;default:return`String(${n})`}}exports.a = Ne; exports.b = jt;
|
|
11
|
+
//# sourceMappingURL=chunk-XXHDWDVY.cjs.map
|