moonflower 1.4.0 → 1.4.2

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.
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("ts-morph"),S=require("../../utils/logger.cjs"),R=require("../manager/OpenApiManager.cjs"),b=new WeakMap,K=t=>{const i=b.get(t);if(i)return i;if(t.getKind()===e.SyntaxKind.Identifier){const s=t.asKind(e.SyntaxKind.Identifier).getImplementations()[0]?.getNode();if(s){const a=s.getParent().getLastChild();if(a===t)throw new Error("Recursive implementation found");const l=K(a);return b.set(t,l),l}const d=t.asKind(e.SyntaxKind.Identifier).getDefinitions()[0]?.getNode();if(d){const a=d.getParent().getLastChild();if(a===t)throw new Error("Recursive implementation found");const l=K(a);return b.set(t,l),l}throw new Error("No implementation nor definition available")}return b.set(t,t),t},N=t=>{const i=t.getChildrenOfKind(e.SyntaxKind.Identifier);return i.length===2?K(i[1]):t.getChildren().reverse().find(d=>d.getKind()!==e.SyntaxKind.GreaterThanToken&&d.getKind()!==e.SyntaxKind.CommaToken&&d.getKind()!==e.SyntaxKind.SemicolonToken)},P=t=>{const i=t.getFirstChildByKind(e.SyntaxKind.SyntaxList);return i.isKind(e.SyntaxKind.SyntaxList)?x(i.getFirstChild()):x(i)},x=t=>{const i=t.getSymbol()?.getName();if(i&&R.OpenApiManager.getInstance().hasExposedModel(i))return[{role:"ref",shape:i,optional:!1}];const s=K(t);if(s.asKind(e.SyntaxKind.UndefinedKeyword))return"undefined";const n=s.asKind(e.SyntaxKind.LiteralType);if(n){if(n.getFirstChildByKind(e.SyntaxKind.TrueKeyword))return"true";if(n.getFirstChildByKind(e.SyntaxKind.FalseKeyword))return"false"}if(s.asKind(e.SyntaxKind.BooleanKeyword)||s.asKind(e.SyntaxKind.TrueKeyword)||s.asKind(e.SyntaxKind.FalseKeyword))return"boolean";if(s.asKind(e.SyntaxKind.StringKeyword)||s.asKind(e.SyntaxKind.StringLiteral))return"string";if(s.asKind(e.SyntaxKind.NumberKeyword)||s.asKind(e.SyntaxKind.NumericLiteral))return"number";if(s.asKind(e.SyntaxKind.BigIntKeyword)||s.asKind(e.SyntaxKind.BigIntLiteral))return"bigint";const r=s.asKind(e.SyntaxKind.TypeLiteral);if(r)return r.getFirstChildByKind(e.SyntaxKind.SyntaxList).getChildrenOfKind(e.SyntaxKind.PropertySignature).map(O=>{const v=O.getFirstChildByKind(e.SyntaxKind.Identifier),V=N(O),U=v.getNextSiblingIfKind(e.SyntaxKind.QuestionToken);return{role:"property",identifier:v.getText(),shape:x(V),optional:V.getType().isNullable()||!!U}});const o=s.asKind(e.SyntaxKind.TypeReference);if(o)return x(o.getFirstChild());if(s.asKind(e.SyntaxKind.PropertyAccessExpression)){const B=K(s.getLastChild());return g(B.asKind(e.SyntaxKind.CallExpression).getReturnType(),B)}const u=s.asKind(e.SyntaxKind.UnionType);if(u)return g(u.getType(),s);const c=s.asKind(e.SyntaxKind.TypeQuery);if(c)return x(c.getLastChild());const A=s.asKind(e.SyntaxKind.QualifiedName);if(A)return x(A.getLastChild());const T=s.asKind(e.SyntaxKind.CallExpression);if(T)return g(T.getReturnType(),T);const L=s.asKind(e.SyntaxKind.AwaitExpression);if(L)return x(L.getChildAtIndex(1));const F=s.asKind(e.SyntaxKind.AsExpression);if(F)return x(F.getChildAtIndex(2));const j=s.getSourceFile().getFilePath().split("/").pop();return S.Logger.warn(`[${j}] Unknown node type: ${s.getKindName()}`),"unknown_1"},_=t=>t.getFirstDescendantByKind(e.SyntaxKind.SyntaxList).getChildrenOfKind(e.SyntaxKind.PropertyAssignment).map(n=>{const a=n.getFirstChild(),l=(()=>{if(a.isKind(e.SyntaxKind.Identifier))return a.getText();if(a.isKind(e.SyntaxKind.StringLiteral))return a.getLiteralText();const r=n.getSourceFile().getFilePath().split("/").pop();return S.Logger.warn(`[${r}] Unknown identifier name: ${a.getText()}`),"unknown_30"})(),p=n.getLastChild(),f=K(p);return{role:"property",identifier:l,shape:m(f),optional:I(f),description:h(f,"description"),errorMessage:h(f,"errorMessage")}})||[],C=t=>{const i=t.asKind(e.SyntaxKind.CallExpression);return i?(i.getReturnType().getSymbol()?.getName()??"").startsWith("Zod"):!1},E=t=>{const i=t.asKind(e.SyntaxKind.CallExpression),d=i.getReturnType().getSymbol()?.getName()??"";if(d==="ZodNumber")return"number";if(d==="ZodString")return"string";if(d==="ZodBoolean")return"boolean";if(d==="ZodBigInt")return"bigint";if(d==="ZodObject"){const l=i.getFirstChildByKind(e.SyntaxKind.SyntaxList)?.getFirstChild()?.asKind(e.SyntaxKind.ObjectLiteralExpression);if(!l)return"unknown_zod_object";const p=l.getFirstChildByKind(e.SyntaxKind.SyntaxList);return p?p.getChildrenOfKind(e.SyntaxKind.PropertyAssignment).map(r=>{const o=r.getFirstChildByKind(e.SyntaxKind.Identifier).getText(),y=r.getLastChild();return{role:"property",identifier:o,shape:C(y)?E(y):m(y),optional:!1}}):[]}if(d==="ZodArray"){const a=i.getFirstChildByKind(e.SyntaxKind.SyntaxList)?.getFirstChild();return a?[{role:"array",shape:C(a)?E(a):m(a),optional:!1}]:"unknown_zod_array"}const n=t.getSourceFile().getFilePath().split("/").pop();return S.Logger.warn(`[${n}] Unknown zod type: ${d}`),"unknown_zod"},m=t=>{if(C(t))return E(t);const i=t.getParent().getFirstChildByKind(e.SyntaxKind.AsExpression);if(i){const r=i.getLastChildByKind(e.SyntaxKind.TypeReference);return P(r)}const s=t.getParent().getFirstChildByKind(e.SyntaxKind.TypeReference);if(s)return P(s);if(t.getParent().getChildrenOfKind(e.SyntaxKind.SyntaxList).length>=2){const r=t.getParent().getFirstChildByKind(e.SyntaxKind.SyntaxList).getFirstChild();return x(r)}const d=t.getParent().getFirstChildByKind(e.SyntaxKind.CallExpression);if(d){const r=K(d.getFirstChildByKind(e.SyntaxKind.SyntaxList).getFirstChild()),o=r.getParent().getFirstChildByKind(e.SyntaxKind.TypeReference);if(o)return g(o.getType(),o,[]);const y=r.getParent().getFirstChildByKind(e.SyntaxKind.ObjectLiteralExpression);if(y)return m(y);if(r.getKind()===e.SyntaxKind.CallExpression||r.getKind()===e.SyntaxKind.IntersectionType)return m(r);const u=t.getSourceFile().getFilePath().split("/").pop();return S.Logger.warn(`[${u}] Unknown call expression argument: ${r.getKindName()}`),"unknown_3"}const a=t.getFirstChildByKind(e.SyntaxKind.SyntaxList).getChildrenOfKind(e.SyntaxKind.PropertyAssignment).find(r=>r.getFirstChildByKind(e.SyntaxKind.Identifier)?.getText()==="parse");if(a){const r=N(a).asKind(e.SyntaxKind.ArrowFunction).getReturnType();return g(r,a)}const l=t.getFirstChildByKind(e.SyntaxKind.SyntaxList)?.getFirstChildByKind(e.SyntaxKind.ImportType);if(l){const r=l.getLastChildByKind(e.SyntaxKind.GreaterThanToken).getChildIndex(),o=l.getChildAtIndex(r-1);return x(o.getFirstChild())}const p=t.isKind(e.SyntaxKind.IntersectionType)?t:t.getParent()?.isKind(e.SyntaxKind.VariableDeclaration)?t.getParent()?.getFirstChildByKind(e.SyntaxKind.IntersectionType):null;if(p){const r=p.getFirstChildByKind(e.SyntaxKind.TypeReference);if(r)return P(r)}const f=t.getSourceFile().getFilePath().split("/").pop();return S.Logger.warn(`[${f}] Unknown import type node`),"unknown_2"},I=t=>{if(C(t))return!1;const i=t.asKind(e.SyntaxKind.CallExpression);if(i){const n=i.getFirstChildByKind(e.SyntaxKind.Identifier);if(n?.getText()==="OptionalParam")return!0;if(n?.getText()==="RequiredParam")return!1;const a=i.getFirstChildByKind(e.SyntaxKind.SyntaxList),l=K(a.getFirstChild());return I(l)}return t.getFirstDescendantByKind(e.SyntaxKind.SyntaxList).getChildrenOfKind(e.SyntaxKind.PropertyAssignment).some(n=>n.getFirstDescendantByKind(e.SyntaxKind.Identifier).getText()==="optional"?N(n).getKind()===e.SyntaxKind.TrueKeyword:!1)},h=(t,i)=>{if(C(t))return"";const s=K(t),d=s.asKind(e.SyntaxKind.CallExpression);if(d){const o=d.getLastChildByKind(e.SyntaxKind.SyntaxList);return h(o,i)}const n=s.asKind(e.SyntaxKind.SyntaxList);if(n)return n.getChildren().map(y=>h(y,i)).find(y=>!!y&&y!=="unknown_25")||"";const a=s.asKind(e.SyntaxKind.ObjectLiteralExpression);if(a){const y=k(a).find(u=>u.identifier===i);return y?Array.isArray(y.value)?"array":y.value||"":""}const l=s.asKind(e.SyntaxKind.IntersectionType);if(l)return l.getTypeNodes().flatMap(o=>h(o,i)).filter(o=>!!o&&o!=="unknown_25")[0]||"unknown_27";const p=s.asKind(e.SyntaxKind.TypeLiteral);if(p)return h(p.getFirstChildByKind(e.SyntaxKind.SyntaxList),i);const f=s.asKind(e.SyntaxKind.PropertySignature);if(f&&s.getFirstDescendantByKind(e.SyntaxKind.Identifier).getText()===i)return N(f).getFirstDescendantByKind(e.SyntaxKind.StringLiteral).getLiteralText();const r=s.getSourceFile().getFilePath().split("/").pop();return S.Logger.dev(`[${r}] Unknown property string value node ${s.getKindName()}`),"unknown_25"},D=t=>{const i=t.getSymbol();if(!t.isObject()||!i)return!1;const s=t.getTypeArguments();return i.getName()==="Promise"&&s.length===1},g=(t,i,s=[])=>{const d=t.getAliasSymbol()?.getName();if(d&&R.OpenApiManager.getInstance().hasExposedModel(d))return[{role:"ref",shape:d,optional:!1}];const n=D(t)?t.getTypeArguments()[0]:t;if(s.some(r=>r===n))return"circular";const a=s.concat(n);if(n.getText()==="void")return"void";if(n.isAny())return"any";if(n.isUnknown())return"unknown";if(n.isNull())return"null";if(n.isUndefined())return"undefined";if(n.isBoolean()||n.isBooleanLiteral())return"boolean";if(n.isStringLiteral())return[{role:"literal_string",shape:String(n.getLiteralValue()),optional:!1}];if(n.isNumberLiteral())return[{role:"literal_number",shape:String(n.getLiteralValue()),optional:!1}];if(n.isString()||n.isTemplateLiteral())return"string";if(n.isNumber())return"number";if(n.getText()==="bigint")return"bigint";if(n.isTuple())return[{role:"tuple",shape:n.getTupleElements().map(r=>({role:"tuple_entry",shape:g(r,i,a),optional:!1})),optional:!1}];if(n.isArray())return[{role:"array",shape:g(n.getArrayElementType(),i,a),optional:!1}];if(n.isObject()){const r=n.getNumberIndexType(),y=n.getBaseTypes()?.find(u=>u.isArray());if(y)return[{role:"array",shape:g(y.getArrayElementType()??r,i,a),optional:!1}]}const l=n.getSymbol()?.getName(),p=new Set(["Buffer","Uint8Array","Int8Array","Uint8ClampedArray","Int16Array","Uint16Array","Int32Array","Uint32Array","Float32Array","Float64Array","BigInt64Array","BigUint64Array","ArrayBuffer","SharedArrayBuffer","ReadableStream"]);if(n.isObject()&&l&&p.has(l))return[{role:"buffer",shape:"buffer",optional:!1}];if(n.isObject()&&l==="RegExp")return"string";if(n.isObject()&&l==="Map"){const o=n.getTypeArguments()[1];return[{role:"record",shape:o?g(o,i,a):"unknown",optional:!1}]}if(n.isObject()&&l==="Set"){const o=n.getTypeArguments()[0];return[{role:"array",shape:o?g(o,i,a):"unknown",optional:!1}]}if(n.isObject()&&n.getProperties().length===0){const r=n.getAliasTypeArguments()[1]??n.getStringIndexType();if(r)return[{role:"record",shape:g(r,i,a),optional:!1}]}if(n.isObject())return l==="Date"||n.getText()==="Date"?"Date":n.getProperties().map(r=>{const o=r.getValueDeclaration()||r.getDeclarations()[0];if(!o)return{role:"property",identifier:r.getName(),shape:g(r.getTypeAtLocation(i),i,a),optional:!1};if(!(o.asKind(e.SyntaxKind.PropertySignature)||o.asKind(e.SyntaxKind.PropertyAssignment)||o.asKind(e.SyntaxKind.ShorthandPropertyAssignment)))return{role:"property",identifier:r.getName(),shape:g(r.getTypeAtLocation(i),i,a),optional:!1};const u=r.getTypeAtLocation(i).isNullable(),c=g(r.getTypeAtLocation(i),i,a);return{role:"property",identifier:r.getName(),shape:c,optional:u}}).filter(r=>r.shape!=="undefined");if(n.isUnion()){const o=n.getUnionTypes().map(c=>({role:"union_entry",shape:g(c,i,a),optional:!1})).filter((c,A,T)=>!T.find((L,F)=>L.shape===c.shape&&F>A)),y=o.some(c=>c.shape==="undefined"),u=o.filter(c=>c.shape!=="undefined");return u.length===1?u[0].shape:[{role:"union",shape:u,optional:y}]}if(n.isIntersection())return n.getIntersectionTypes().map(y=>g(y,i,a)).filter(y=>typeof y!="string").reduce((y,u)=>[...y,...u],[]);const f=i.getSourceFile().getFilePath().split("/").pop();return S.Logger.warn(`[${f}] Unknown type shape node ${t.getText()}`),"unknown_5"},w=t=>{if(t.isKind(e.SyntaxKind.Identifier))return w(K(t));if(t.isKind(e.SyntaxKind.StringLiteral))return t.getLiteralValue();if(t.isKind(e.SyntaxKind.ArrayLiteralExpression))return t.forEachChildAsArray().map(s=>w(s));if(t.isKind(e.SyntaxKind.PropertyAccessExpression))return w(N(t));if(t.isKind(e.SyntaxKind.ObjectLiteralExpression))return k(t);const i=t.getSourceFile().getFilePath().split("/").pop();return S.Logger.dev(`[${i}] Unknown literal value node ${t.getKindName()}`),"unknown_6"},M=t=>{const i=t.getFirstDescendantByKind(e.SyntaxKind.CallExpression);if(!i)return null;const s=i.getArguments()[0];if(!s)return null;const d=s.getType();return d.isStringLiteral()?d.getLiteralValue():null},k=t=>t.getFirstDescendantByKind(e.SyntaxKind.SyntaxList).getChildrenOfKind(e.SyntaxKind.PropertyAssignment).map(n=>{const l=n.getFirstDescendantByKind(e.SyntaxKind.Identifier).getText(),p=n.getLastChild(),f=K(p),r=w(f);return{identifier:l,value:r}})||[];exports.findNodeImplementation=K;exports.findPropertyAssignmentValueNode=N;exports.getProperTypeShape=g;exports.getRecursiveNodeShape=x;exports.getShapeOfValidatorLiteral=_;exports.getTypeReferenceShape=P;exports.getValidatorPropertyOptionality=I;exports.getValidatorPropertyShape=m;exports.getValidatorPropertyStringValue=h;exports.getValuesOfObjectLiteral=k;exports.resolveEndpointPath=M;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("ts-morph"),S=require("../../utils/logger.cjs"),_=require("../manager/OpenApiManager.cjs"),b=new WeakMap,K=t=>{const i=b.get(t);if(i)return i;if(t.getKind()===e.SyntaxKind.Identifier){const s=t.asKind(e.SyntaxKind.Identifier).getImplementations()[0]?.getNode();if(s){const a=s.getParent().getLastChild();if(a===t)throw new Error("Recursive implementation found");const l=K(a);return b.set(t,l),l}const d=t.asKind(e.SyntaxKind.Identifier).getDefinitions()[0]?.getNode();if(d){const a=d.getParent().getLastChild();if(a===t)throw new Error("Recursive implementation found");const l=K(a);return b.set(t,l),l}throw new Error("No implementation nor definition available")}return b.set(t,t),t},T=t=>{const i=t.getChildrenOfKind(e.SyntaxKind.Identifier);return i.length===2?K(i[1]):t.getChildren().reverse().find(d=>d.getKind()!==e.SyntaxKind.GreaterThanToken&&d.getKind()!==e.SyntaxKind.CommaToken&&d.getKind()!==e.SyntaxKind.SemicolonToken)},P=t=>{const i=t.getFirstChildByKind(e.SyntaxKind.SyntaxList);return i.isKind(e.SyntaxKind.SyntaxList)?x(i.getFirstChild()):x(i)},x=t=>{const i=t.getSymbol()?.getName();if(i&&_.OpenApiManager.getInstance().hasExposedModel(i))return[{role:"ref",shape:i,optional:!1}];const s=K(t);if(s.asKind(e.SyntaxKind.UndefinedKeyword))return"undefined";const n=s.asKind(e.SyntaxKind.LiteralType);if(n){if(n.getFirstChildByKind(e.SyntaxKind.TrueKeyword))return"true";if(n.getFirstChildByKind(e.SyntaxKind.FalseKeyword))return"false"}if(s.asKind(e.SyntaxKind.BooleanKeyword)||s.asKind(e.SyntaxKind.TrueKeyword)||s.asKind(e.SyntaxKind.FalseKeyword))return"boolean";if(s.asKind(e.SyntaxKind.StringKeyword)||s.asKind(e.SyntaxKind.StringLiteral))return"string";if(s.asKind(e.SyntaxKind.NumberKeyword)||s.asKind(e.SyntaxKind.NumericLiteral))return"number";if(s.asKind(e.SyntaxKind.BigIntKeyword)||s.asKind(e.SyntaxKind.BigIntLiteral))return"bigint";const r=s.asKind(e.SyntaxKind.TypeLiteral);if(r)return r.getFirstChildByKind(e.SyntaxKind.SyntaxList).getChildrenOfKind(e.SyntaxKind.PropertySignature).map(O=>{const v=O.getFirstChildByKind(e.SyntaxKind.Identifier),V=T(O),j=v.getNextSiblingIfKind(e.SyntaxKind.QuestionToken);return{role:"property",identifier:v.getText(),shape:x(V),optional:V.getType().isNullable()||!!j}});const o=s.asKind(e.SyntaxKind.TypeReference);if(o)return x(o.getFirstChild());if(s.asKind(e.SyntaxKind.PropertyAccessExpression)){const E=K(s.getLastChild());return g(E.asKind(e.SyntaxKind.CallExpression).getReturnType(),E)}const c=s.asKind(e.SyntaxKind.UnionType);if(c)return g(c.getType(),s);const f=s.asKind(e.SyntaxKind.TypeQuery);if(f)return x(f.getLastChild());const A=s.asKind(e.SyntaxKind.QualifiedName);if(A)return x(A.getLastChild());const C=s.asKind(e.SyntaxKind.CallExpression);if(C)return g(C.getReturnType(),C);const F=s.asKind(e.SyntaxKind.AwaitExpression);if(F)return x(F.getChildAtIndex(1));const L=s.asKind(e.SyntaxKind.AsExpression);if(L)return x(L.getChildAtIndex(2));const R=s.getSourceFile().getFilePath().split("/").pop();return S.Logger.warn(`[${R}] Unknown node type: ${s.getKindName()}`),"unknown_1"},U=t=>t.getFirstDescendantByKind(e.SyntaxKind.SyntaxList).getChildrenOfKind(e.SyntaxKind.PropertyAssignment).map(n=>{const a=n.getFirstChild(),l=(()=>{if(a.isKind(e.SyntaxKind.Identifier))return a.getText();if(a.isKind(e.SyntaxKind.StringLiteral))return a.getLiteralText();const r=n.getSourceFile().getFilePath().split("/").pop();return S.Logger.warn(`[${r}] Unknown identifier name: ${a.getText()}`),"unknown_30"})(),u=n.getLastChild(),p=K(u);return{role:"property",identifier:l,shape:m(p),optional:I(p),description:h(p,"description"),errorMessage:h(p,"errorMessage")}})||[],N=t=>{const i=t.asKind(e.SyntaxKind.CallExpression);return i?(i.getReturnType().getSymbol()?.getName()??"").startsWith("Zod"):!1},w=t=>{const i=t.asKind(e.SyntaxKind.CallExpression),s=i.getReturnType(),d=s.getSymbol()?.getName()??"";if(d==="ZodNumber")return"number";if(d==="ZodString")return"string";if(d==="ZodBoolean")return"boolean";if(d==="ZodBigInt")return"bigint";if(d==="ZodObject"){const l=i.getFirstChildByKind(e.SyntaxKind.SyntaxList)?.getFirstChild()?.asKind(e.SyntaxKind.ObjectLiteralExpression);if(!l)return"unknown_zod_object";const u=l.getFirstChildByKind(e.SyntaxKind.SyntaxList);return u?u.getChildrenOfKind(e.SyntaxKind.PropertyAssignment).map(r=>{const o=r.getFirstChildByKind(e.SyntaxKind.Identifier).getText(),y=r.getLastChild();return{role:"property",identifier:o,shape:N(y)?w(y):m(y),optional:!1}}):[]}if(d==="ZodArray"){const a=i.getFirstChildByKind(e.SyntaxKind.SyntaxList)?.getFirstChild();return a?[{role:"array",shape:N(a)?w(a):m(a),optional:!1}]:"unknown_zod_array"}if(d==="ZodEnum"){const a=s.getTypeArguments();if(a.length>0){const p=a[0].getProperties().map(r=>({role:"union_entry",shape:g(r.getTypeAtLocation(i),i,[]),optional:!1}));if(p.length===1)return p[0].shape;if(p.length>1)return[{role:"union",shape:p,optional:!1}]}return"unknown_zod_enum"}if(d==="ZodOptional"){const a=i.getFirstChildByKind(e.SyntaxKind.PropertyAccessExpression)?.getFirstChildByKind(e.SyntaxKind.CallExpression);return a&&N(a)?w(a):"unknown_zod_optional"}const n=t.getSourceFile().getFilePath().split("/").pop();return S.Logger.warn(`[${n}] Unknown zod type: ${d}`),"unknown_zod"},m=t=>{if(N(t))return w(t);const i=t.getParent().getFirstChildByKind(e.SyntaxKind.AsExpression);if(i){const r=i.getLastChildByKind(e.SyntaxKind.TypeReference);return P(r)}const s=t.getParent().getFirstChildByKind(e.SyntaxKind.TypeReference);if(s)return P(s);if(t.getParent().getChildrenOfKind(e.SyntaxKind.SyntaxList).length>=2){const r=t.getParent().getFirstChildByKind(e.SyntaxKind.SyntaxList).getFirstChild();return x(r)}const d=t.getParent().getFirstChildByKind(e.SyntaxKind.CallExpression);if(d){const r=K(d.getFirstChildByKind(e.SyntaxKind.SyntaxList).getFirstChild()),o=r.getParent().getFirstChildByKind(e.SyntaxKind.TypeReference);if(o)return g(o.getType(),o,[]);const y=r.getParent().getFirstChildByKind(e.SyntaxKind.ObjectLiteralExpression);if(y)return m(y);if(r.getKind()===e.SyntaxKind.CallExpression||r.getKind()===e.SyntaxKind.IntersectionType)return m(r);const c=t.getSourceFile().getFilePath().split("/").pop();return S.Logger.warn(`[${c}] Unknown call expression argument: ${r.getKindName()}`),"unknown_3"}const a=t.getFirstChildByKind(e.SyntaxKind.SyntaxList).getChildrenOfKind(e.SyntaxKind.PropertyAssignment).find(r=>r.getFirstChildByKind(e.SyntaxKind.Identifier)?.getText()==="parse");if(a){const r=T(a).asKind(e.SyntaxKind.ArrowFunction).getReturnType();return g(r,a)}const l=t.getFirstChildByKind(e.SyntaxKind.SyntaxList)?.getFirstChildByKind(e.SyntaxKind.ImportType);if(l){const r=l.getLastChildByKind(e.SyntaxKind.GreaterThanToken).getChildIndex(),o=l.getChildAtIndex(r-1);return x(o.getFirstChild())}const u=t.isKind(e.SyntaxKind.IntersectionType)?t:t.getParent()?.isKind(e.SyntaxKind.VariableDeclaration)?t.getParent()?.getFirstChildByKind(e.SyntaxKind.IntersectionType):null;if(u){const r=u.getFirstChildByKind(e.SyntaxKind.TypeReference);if(r)return P(r)}const p=t.getSourceFile().getFilePath().split("/").pop();return S.Logger.warn(`[${p}] Unknown import type node`),"unknown_2"},I=t=>{if(N(t))return(t.asKind(e.SyntaxKind.CallExpression).getReturnType().getSymbol()?.getName()??"")==="ZodOptional";const i=t.asKind(e.SyntaxKind.CallExpression);if(i){const n=i.getFirstChildByKind(e.SyntaxKind.Identifier);if(n?.getText()==="OptionalParam")return!0;if(n?.getText()==="RequiredParam")return!1;const a=i.getFirstChildByKind(e.SyntaxKind.SyntaxList),l=K(a.getFirstChild());return I(l)}return t.getFirstDescendantByKind(e.SyntaxKind.SyntaxList).getChildrenOfKind(e.SyntaxKind.PropertyAssignment).some(n=>n.getFirstDescendantByKind(e.SyntaxKind.Identifier).getText()==="optional"?T(n).getKind()===e.SyntaxKind.TrueKeyword:!1)},h=(t,i)=>{if(N(t))return"";const s=K(t),d=s.asKind(e.SyntaxKind.CallExpression);if(d){const o=d.getLastChildByKind(e.SyntaxKind.SyntaxList);return h(o,i)}const n=s.asKind(e.SyntaxKind.SyntaxList);if(n)return n.getChildren().map(y=>h(y,i)).find(y=>!!y&&y!=="unknown_25")||"";const a=s.asKind(e.SyntaxKind.ObjectLiteralExpression);if(a){const y=k(a).find(c=>c.identifier===i);return y?Array.isArray(y.value)?"array":y.value||"":""}const l=s.asKind(e.SyntaxKind.IntersectionType);if(l)return l.getTypeNodes().flatMap(o=>h(o,i)).filter(o=>!!o&&o!=="unknown_25")[0]||"unknown_27";const u=s.asKind(e.SyntaxKind.TypeLiteral);if(u)return h(u.getFirstChildByKind(e.SyntaxKind.SyntaxList),i);const p=s.asKind(e.SyntaxKind.PropertySignature);if(p&&s.getFirstDescendantByKind(e.SyntaxKind.Identifier).getText()===i)return T(p).getFirstDescendantByKind(e.SyntaxKind.StringLiteral).getLiteralText();const r=s.getSourceFile().getFilePath().split("/").pop();return S.Logger.dev(`[${r}] Unknown property string value node ${s.getKindName()}`),"unknown_25"},D=t=>{const i=t.getSymbol();if(!t.isObject()||!i)return!1;const s=t.getTypeArguments();return i.getName()==="Promise"&&s.length===1},g=(t,i,s=[])=>{const d=t.getAliasSymbol()?.getName();if(d&&_.OpenApiManager.getInstance().hasExposedModel(d))return[{role:"ref",shape:d,optional:!1}];const n=D(t)?t.getTypeArguments()[0]:t;if(s.some(r=>r===n))return"circular";const a=s.concat(n);if(n.getText()==="void")return"void";if(n.isAny())return"any";if(n.isUnknown())return"unknown";if(n.isNull())return"null";if(n.isUndefined())return"undefined";if(n.isBoolean()||n.isBooleanLiteral())return"boolean";if(n.isStringLiteral())return[{role:"literal_string",shape:String(n.getLiteralValue()),optional:!1}];if(n.isNumberLiteral())return[{role:"literal_number",shape:String(n.getLiteralValue()),optional:!1}];if(n.isString()||n.isTemplateLiteral())return"string";if(n.isNumber())return"number";if(n.getText()==="bigint")return"bigint";if(n.isTuple())return[{role:"tuple",shape:n.getTupleElements().map(r=>({role:"tuple_entry",shape:g(r,i,a),optional:!1})),optional:!1}];if(n.isArray())return[{role:"array",shape:g(n.getArrayElementType(),i,a),optional:!1}];if(n.isObject()){const r=n.getNumberIndexType(),y=n.getBaseTypes()?.find(c=>c.isArray());if(y)return[{role:"array",shape:g(y.getArrayElementType()??r,i,a),optional:!1}]}const l=n.getSymbol()?.getName(),u=new Set(["Buffer","Uint8Array","Int8Array","Uint8ClampedArray","Int16Array","Uint16Array","Int32Array","Uint32Array","Float32Array","Float64Array","BigInt64Array","BigUint64Array","ArrayBuffer","SharedArrayBuffer","ReadableStream"]);if(n.isObject()&&l&&u.has(l))return[{role:"buffer",shape:"buffer",optional:!1}];if(n.isObject()&&l==="RegExp")return"string";if(n.isObject()&&l==="Map"){const o=n.getTypeArguments()[1];return[{role:"record",shape:o?g(o,i,a):"unknown",optional:!1}]}if(n.isObject()&&l==="Set"){const o=n.getTypeArguments()[0];return[{role:"array",shape:o?g(o,i,a):"unknown",optional:!1}]}if(n.isObject()&&n.getProperties().length===0){const r=n.getAliasTypeArguments()[1]??n.getStringIndexType();if(r)return[{role:"record",shape:g(r,i,a),optional:!1}]}if(n.isObject())return l==="Date"||n.getText()==="Date"?"Date":n.getProperties().map(r=>{const o=r.getValueDeclaration()||r.getDeclarations()[0];if(!o)return{role:"property",identifier:r.getName(),shape:g(r.getTypeAtLocation(i),i,a),optional:!1};if(!(o.asKind(e.SyntaxKind.PropertySignature)||o.asKind(e.SyntaxKind.PropertyAssignment)||o.asKind(e.SyntaxKind.ShorthandPropertyAssignment)))return{role:"property",identifier:r.getName(),shape:g(r.getTypeAtLocation(i),i,a),optional:!1};const c=r.getTypeAtLocation(i).isNullable(),f=g(r.getTypeAtLocation(i),i,a);return{role:"property",identifier:r.getName(),shape:f,optional:c}}).filter(r=>r.shape!=="undefined");if(n.isUnion()){const o=n.getUnionTypes().map(f=>({role:"union_entry",shape:g(f,i,a),optional:!1})).filter((f,A,C)=>!C.find((F,L)=>F.shape===f.shape&&L>A)),y=o.some(f=>f.shape==="undefined"),c=o.filter(f=>f.shape!=="undefined");return c.length===1?c[0].shape:[{role:"union",shape:c,optional:y}]}if(n.isIntersection())return n.getIntersectionTypes().map(y=>g(y,i,a)).filter(y=>typeof y!="string").reduce((y,c)=>[...y,...c],[]);const p=i.getSourceFile().getFilePath().split("/").pop();return S.Logger.warn(`[${p}] Unknown type shape node ${t.getText()}`),"unknown_5"},B=t=>{if(t.isKind(e.SyntaxKind.Identifier))return B(K(t));if(t.isKind(e.SyntaxKind.StringLiteral))return t.getLiteralValue();if(t.isKind(e.SyntaxKind.ArrayLiteralExpression))return t.forEachChildAsArray().map(s=>B(s));if(t.isKind(e.SyntaxKind.PropertyAccessExpression))return B(T(t));if(t.isKind(e.SyntaxKind.ObjectLiteralExpression))return k(t);const i=t.getSourceFile().getFilePath().split("/").pop();return S.Logger.dev(`[${i}] Unknown literal value node ${t.getKindName()}`),"unknown_6"},M=t=>{const i=t.getFirstDescendantByKind(e.SyntaxKind.CallExpression);if(!i)return null;const s=i.getArguments()[0];if(!s)return null;const d=s.getType();return d.isStringLiteral()?d.getLiteralValue():null},k=t=>t.getFirstDescendantByKind(e.SyntaxKind.SyntaxList).getChildrenOfKind(e.SyntaxKind.PropertyAssignment).map(n=>{const l=n.getFirstDescendantByKind(e.SyntaxKind.Identifier).getText(),u=n.getLastChild(),p=K(u),r=B(p);return{identifier:l,value:r}})||[];exports.findNodeImplementation=K;exports.findPropertyAssignmentValueNode=T;exports.getProperTypeShape=g;exports.getRecursiveNodeShape=x;exports.getShapeOfValidatorLiteral=U;exports.getTypeReferenceShape=P;exports.getValidatorPropertyOptionality=I;exports.getValidatorPropertyShape=m;exports.getValidatorPropertyStringValue=h;exports.getValuesOfObjectLiteral=k;exports.resolveEndpointPath=M;
2
2
  //# sourceMappingURL=nodeParsers.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"nodeParsers.cjs","sources":["../../../src/openapi/analyzerModule/nodeParsers.ts"],"sourcesContent":["import {\n\tNode,\n\tPropertyAccessExpression,\n\tPropertyAssignment,\n\tPropertySignature,\n\tShorthandPropertyAssignment,\n\tSyntaxKind,\n\tts,\n\tType,\n\tTypeReferenceNode,\n} from 'ts-morph'\n\nimport { Logger } from '../../utils/logger'\nimport { OpenApiManager } from '../manager/OpenApiManager'\nimport { ShapeOfProperty, ShapeOfType, ShapeOfUnionEntry } from './types'\n\nconst implementationCache = new WeakMap<Node, Node>()\n\nexport const findNodeImplementation = (node: Node): Node => {\n\tconst cached = implementationCache.get(node)\n\tif (cached) {\n\t\treturn cached\n\t}\n\n\tif (node.getKind() === SyntaxKind.Identifier) {\n\t\tconst implementationNode = node.asKind(SyntaxKind.Identifier)!.getImplementations()[0]?.getNode()\n\t\tif (implementationNode) {\n\t\t\tconst implementationParentNode = implementationNode.getParent()!\n\t\t\tconst assignmentValueNode = implementationParentNode.getLastChild()!\n\t\t\tif (assignmentValueNode === node) {\n\t\t\t\tthrow new Error('Recursive implementation found')\n\t\t\t}\n\t\t\tconst result = findNodeImplementation(assignmentValueNode)\n\t\t\timplementationCache.set(node, result)\n\t\t\treturn result\n\t\t}\n\n\t\tconst definitionNode = node.asKind(SyntaxKind.Identifier)!.getDefinitions()[0]?.getNode()\n\t\tif (definitionNode) {\n\t\t\tconst definitionParentNode = definitionNode.getParent()!\n\t\t\tconst assignmentValueNode = definitionParentNode.getLastChild()!\n\t\t\tif (assignmentValueNode === node) {\n\t\t\t\tthrow new Error('Recursive implementation found')\n\t\t\t}\n\t\t\tconst result = findNodeImplementation(assignmentValueNode)\n\t\t\timplementationCache.set(node, result)\n\t\t\treturn result\n\t\t}\n\t\tthrow new Error('No implementation nor definition available')\n\t}\n\n\timplementationCache.set(node, node)\n\treturn node\n}\n\nexport const findPropertyAssignmentValueNode = (\n\tnode:\n\t\t| PropertyAssignment\n\t\t| TypeReferenceNode\n\t\t| PropertySignature\n\t\t| PropertyAccessExpression\n\t\t| ShorthandPropertyAssignment,\n): Node => {\n\tconst identifierChildren = node.getChildrenOfKind(SyntaxKind.Identifier)\n\tif (identifierChildren.length === 2) {\n\t\treturn findNodeImplementation(identifierChildren[1])\n\t}\n\tconst lastMatchingChild = node.getChildren().reverse()\n\treturn lastMatchingChild.find(\n\t\t(child) =>\n\t\t\tchild.getKind() !== SyntaxKind.GreaterThanToken &&\n\t\t\tchild.getKind() !== SyntaxKind.CommaToken &&\n\t\t\tchild.getKind() !== SyntaxKind.SemicolonToken,\n\t)!\n}\n\nexport const getTypeReferenceShape = (node: TypeReferenceNode): ShapeOfType['shape'] => {\n\tconst firstChild = node.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\tif (firstChild.isKind(SyntaxKind.SyntaxList)) {\n\t\treturn getRecursiveNodeShape(firstChild.getFirstChild()!)\n\t} else {\n\t\treturn getRecursiveNodeShape(firstChild)\n\t}\n}\n\nexport const getRecursiveNodeShape = (nodeOrReference: Node): ShapeOfType['shape'] => {\n\tconst typeName = nodeOrReference.getSymbol()?.getName()\n\tif (typeName && OpenApiManager.getInstance().hasExposedModel(typeName)) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'ref',\n\t\t\t\tshape: typeName,\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tconst node = findNodeImplementation(nodeOrReference)\n\n\t// Undefined\n\tconst undefinedNode = node.asKind(SyntaxKind.UndefinedKeyword)\n\tif (undefinedNode) {\n\t\treturn 'undefined'\n\t}\n\n\t// Literal type\n\tconst literalNode = node.asKind(SyntaxKind.LiteralType)\n\tif (literalNode) {\n\t\tif (literalNode.getFirstChildByKind(SyntaxKind.TrueKeyword)) {\n\t\t\treturn 'true'\n\t\t}\n\t\tif (literalNode.getFirstChildByKind(SyntaxKind.FalseKeyword)) {\n\t\t\treturn 'false'\n\t\t}\n\t}\n\n\t// Boolean literal\n\tconst booleanLiteralNode =\n\t\tnode.asKind(SyntaxKind.BooleanKeyword) ||\n\t\tnode.asKind(SyntaxKind.TrueKeyword) ||\n\t\tnode.asKind(SyntaxKind.FalseKeyword)\n\tif (booleanLiteralNode) {\n\t\treturn 'boolean'\n\t}\n\n\t// String literal\n\tconst stringLiteralNode = node.asKind(SyntaxKind.StringKeyword) || node.asKind(SyntaxKind.StringLiteral)\n\tif (stringLiteralNode) {\n\t\treturn 'string'\n\t}\n\n\t// Number literal\n\tconst numberLiteralNode = node.asKind(SyntaxKind.NumberKeyword) || node.asKind(SyntaxKind.NumericLiteral)\n\tif (numberLiteralNode) {\n\t\treturn 'number'\n\t}\n\n\t// BigInt literal\n\tconst bigIntNode = node.asKind(SyntaxKind.BigIntKeyword) || node.asKind(SyntaxKind.BigIntLiteral)\n\tif (bigIntNode) {\n\t\treturn 'bigint'\n\t}\n\n\t// Type literal\n\tconst typeLiteralNode = node.asKind(SyntaxKind.TypeLiteral)\n\tif (typeLiteralNode) {\n\t\tconst properties = typeLiteralNode\n\t\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\t\t.getChildrenOfKind(SyntaxKind.PropertySignature)\n\n\t\tconst propertyShapes = properties.map((propNode) => {\n\t\t\tconst identifier = propNode.getFirstChildByKind(SyntaxKind.Identifier)!\n\t\t\tconst valueNode = findPropertyAssignmentValueNode(propNode)\n\t\t\tconst questionMarkToken = identifier.getNextSiblingIfKind(SyntaxKind.QuestionToken)\n\t\t\treturn {\n\t\t\t\trole: 'property' as const,\n\t\t\t\tidentifier: identifier.getText(),\n\t\t\t\tshape: getRecursiveNodeShape(valueNode),\n\t\t\t\toptional: valueNode.getType().isNullable() || !!questionMarkToken,\n\t\t\t}\n\t\t})\n\t\treturn propertyShapes\n\t}\n\n\t// Type reference\n\tconst typeReferenceNode = node.asKind(SyntaxKind.TypeReference)\n\tif (typeReferenceNode) {\n\t\treturn getRecursiveNodeShape(typeReferenceNode.getFirstChild()!)\n\t}\n\n\t// Property access expression\n\tconst propertyAccessNode = node.asKind(SyntaxKind.PropertyAccessExpression)\n\tif (propertyAccessNode) {\n\t\tconst lastChild = findNodeImplementation(node.getLastChild()!)\n\t\treturn getProperTypeShape(lastChild.asKind(SyntaxKind.CallExpression)!.getReturnType(), lastChild)\n\t}\n\n\t// Union type\n\tconst unionTypeNode = node.asKind(SyntaxKind.UnionType)\n\tif (unionTypeNode) {\n\t\treturn getProperTypeShape(unionTypeNode.getType(), node)\n\t}\n\n\t// Typeof query\n\tconst typeQueryNode = node.asKind(SyntaxKind.TypeQuery)\n\tif (typeQueryNode) {\n\t\treturn getRecursiveNodeShape(typeQueryNode.getLastChild()!)\n\t}\n\n\t// Qualified name\n\tconst qualifiedNameNode = node.asKind(SyntaxKind.QualifiedName)\n\tif (qualifiedNameNode) {\n\t\treturn getRecursiveNodeShape(qualifiedNameNode.getLastChild()!)\n\t}\n\n\t// Call expression\n\tconst callExpressionNode = node.asKind(SyntaxKind.CallExpression)\n\tif (callExpressionNode) {\n\t\treturn getProperTypeShape(callExpressionNode.getReturnType(), callExpressionNode)\n\t}\n\n\t// Await expression\n\tconst awaitExpressionNode = node.asKind(SyntaxKind.AwaitExpression)\n\tif (awaitExpressionNode) {\n\t\treturn getRecursiveNodeShape(awaitExpressionNode.getChildAtIndex(1)!)\n\t}\n\n\t// 'As' Expression\n\tconst asExpressionNode = node.asKind(SyntaxKind.AsExpression)\n\tif (asExpressionNode) {\n\t\treturn getRecursiveNodeShape(asExpressionNode.getChildAtIndex(2)!)\n\t}\n\n\t// TODO\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown node type: ${node.getKindName()}`)\n\treturn 'unknown_1'\n}\n\nexport const getShapeOfValidatorLiteral = (\n\tobjectLiteralNode: Node<ts.ObjectLiteralExpression>,\n): (ShapeOfProperty & { description: string; errorMessage: string })[] => {\n\tconst syntaxListNode = objectLiteralNode.getFirstDescendantByKind(SyntaxKind.SyntaxList)!\n\tconst assignmentNodes = syntaxListNode.getChildrenOfKind(SyntaxKind.PropertyAssignment)!\n\n\tconst properties = assignmentNodes.map((node) => {\n\t\tconst identifierNode = node.getFirstChild()!\n\t\tconst identifierName = (() => {\n\t\t\tif (identifierNode.isKind(SyntaxKind.Identifier)) {\n\t\t\t\treturn identifierNode.getText()\n\t\t\t}\n\t\t\tif (identifierNode.isKind(SyntaxKind.StringLiteral)) {\n\t\t\t\treturn identifierNode.getLiteralText()\n\t\t\t}\n\t\t\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\t\t\tLogger.warn(`[${fileName}] Unknown identifier name: ${identifierNode.getText()}`)\n\t\t\treturn 'unknown_30'\n\t\t})()\n\n\t\tconst assignmentValueNode = node.getLastChild()!\n\t\tconst innerLiteralNode = findNodeImplementation(assignmentValueNode)\n\n\t\treturn {\n\t\t\trole: 'property' as const,\n\t\t\tidentifier: identifierName,\n\t\t\tshape: getValidatorPropertyShape(innerLiteralNode),\n\t\t\toptional: getValidatorPropertyOptionality(innerLiteralNode),\n\t\t\tdescription: getValidatorPropertyStringValue(innerLiteralNode, 'description'),\n\t\t\terrorMessage: getValidatorPropertyStringValue(innerLiteralNode, 'errorMessage'),\n\t\t}\n\t})\n\n\treturn properties || []\n}\n\nconst isZodCallExpression = (node: Node): boolean => {\n\tconst callExpression = node.asKind(SyntaxKind.CallExpression)\n\tif (!callExpression) {\n\t\treturn false\n\t}\n\tconst returnType = callExpression.getReturnType()\n\tconst typeName = returnType.getSymbol()?.getName() ?? ''\n\treturn typeName.startsWith('Zod')\n}\n\nconst getZodCallShape = (node: Node): ShapeOfType['shape'] => {\n\tconst callExpression = node.asKind(SyntaxKind.CallExpression)!\n\tconst returnType = callExpression.getReturnType()\n\tconst typeName = returnType.getSymbol()?.getName() ?? ''\n\n\tif (typeName === 'ZodNumber') {\n\t\treturn 'number'\n\t}\n\tif (typeName === 'ZodString') {\n\t\treturn 'string'\n\t}\n\tif (typeName === 'ZodBoolean') {\n\t\treturn 'boolean'\n\t}\n\tif (typeName === 'ZodBigInt') {\n\t\treturn 'bigint'\n\t}\n\n\tif (typeName === 'ZodObject') {\n\t\tconst argNode = callExpression.getFirstChildByKind(SyntaxKind.SyntaxList)?.getFirstChild()\n\t\tconst objectLiteral = argNode?.asKind(SyntaxKind.ObjectLiteralExpression)\n\t\tif (!objectLiteral) {\n\t\t\treturn 'unknown_zod_object'\n\t\t}\n\t\tconst syntaxList = objectLiteral.getFirstChildByKind(SyntaxKind.SyntaxList)\n\t\tif (!syntaxList) {\n\t\t\treturn []\n\t\t}\n\t\tconst properties = syntaxList.getChildrenOfKind(SyntaxKind.PropertyAssignment)\n\t\treturn properties.map((prop) => {\n\t\t\tconst identifier = prop.getFirstChildByKind(SyntaxKind.Identifier)!.getText()\n\t\t\tconst valueNode = prop.getLastChild()!\n\t\t\treturn {\n\t\t\t\trole: 'property' as const,\n\t\t\t\tidentifier,\n\t\t\t\tshape: isZodCallExpression(valueNode)\n\t\t\t\t\t? getZodCallShape(valueNode)\n\t\t\t\t\t: getValidatorPropertyShape(valueNode),\n\t\t\t\toptional: false,\n\t\t\t}\n\t\t})\n\t}\n\n\tif (typeName === 'ZodArray') {\n\t\tconst argNode = callExpression.getFirstChildByKind(SyntaxKind.SyntaxList)?.getFirstChild()\n\t\tif (!argNode) {\n\t\t\treturn 'unknown_zod_array'\n\t\t}\n\t\tconst elementShape = isZodCallExpression(argNode)\n\t\t\t? getZodCallShape(argNode)\n\t\t\t: getValidatorPropertyShape(argNode)\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'array' as const,\n\t\t\t\tshape: elementShape,\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown zod type: ${typeName}`)\n\treturn 'unknown_zod'\n}\n\nexport const getValidatorPropertyShape = (innerLiteralNode: Node): ShapeOfType['shape'] => {\n\t// Zod validator (e.g. z.number(), z.string(), z.object({...}), z.array(...))\n\tif (isZodCallExpression(innerLiteralNode)) {\n\t\treturn getZodCallShape(innerLiteralNode)\n\t}\n\n\t// Inline definition with `as Validator<...>` clause\n\tconst inlineValidatorAsExpression = innerLiteralNode\n\t\t.getParent()!\n\t\t.getFirstChildByKind(SyntaxKind.AsExpression)\n\tif (inlineValidatorAsExpression) {\n\t\tconst typeReference = inlineValidatorAsExpression.getLastChildByKind(SyntaxKind.TypeReference)!\n\t\treturn getTypeReferenceShape(typeReference)\n\t}\n\n\t// Variable with `: Validator<...>` clause\n\tconst childTypeReferenceNode = innerLiteralNode.getParent()!.getFirstChildByKind(SyntaxKind.TypeReference)\n\tif (childTypeReferenceNode) {\n\t\treturn getTypeReferenceShape(childTypeReferenceNode)\n\t}\n\n\t// `RequiredParam<...>` inline call expression\n\tif (innerLiteralNode.getParent()!.getChildrenOfKind(SyntaxKind.SyntaxList).length >= 2) {\n\t\tconst typeNode = innerLiteralNode\n\t\t\t.getParent()!\n\t\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\t\t.getFirstChild()!\n\t\treturn getRecursiveNodeShape(typeNode)\n\t}\n\n\t// `RequestParam | RequiredParam | OptionalParam` call expression\n\tconst childCallExpressionNode = innerLiteralNode.getParent()!.getFirstChildByKind(SyntaxKind.CallExpression)\n\tif (childCallExpressionNode) {\n\t\tconst callExpressionArgument = findNodeImplementation(\n\t\t\tchildCallExpressionNode.getFirstChildByKind(SyntaxKind.SyntaxList)!.getFirstChild()!,\n\t\t)\n\n\t\t// Param is a type reference\n\t\tconst typeReferenceNode = callExpressionArgument\n\t\t\t.getParent()!\n\t\t\t.getFirstChildByKind(SyntaxKind.TypeReference)!\n\t\tif (typeReferenceNode) {\n\t\t\treturn getProperTypeShape(typeReferenceNode.getType(), typeReferenceNode, [])\n\t\t}\n\n\t\tconst thingyNode = callExpressionArgument\n\t\t\t.getParent()!\n\t\t\t.getFirstChildByKind(SyntaxKind.ObjectLiteralExpression)!\n\t\tif (thingyNode) {\n\t\t\treturn getValidatorPropertyShape(thingyNode)\n\t\t}\n\n\t\tif (callExpressionArgument.getKind() === SyntaxKind.CallExpression) {\n\t\t\treturn getValidatorPropertyShape(callExpressionArgument)\n\t\t}\n\n\t\tif (callExpressionArgument.getKind() === SyntaxKind.IntersectionType) {\n\t\t\treturn getValidatorPropertyShape(callExpressionArgument)\n\t\t}\n\n\t\tconst fileName = innerLiteralNode.getSourceFile().getFilePath().split('/').pop()\n\t\tLogger.warn(`[${fileName}] Unknown call expression argument: ${callExpressionArgument.getKindName()}`)\n\t\treturn 'unknown_3'\n\t}\n\n\t// Attempting to infer type from `parse` function\n\tconst innerNodePropertyAssignments = innerLiteralNode\n\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\t.getChildrenOfKind(SyntaxKind.PropertyAssignment)\n\tconst parsePropertyAssignment = innerNodePropertyAssignments.find((prop) => {\n\t\treturn prop.getFirstChildByKind(SyntaxKind.Identifier)?.getText() === 'parse'\n\t})\n\tif (parsePropertyAssignment) {\n\t\tconst returnType = findPropertyAssignmentValueNode(parsePropertyAssignment)\n\t\t\t.asKind(SyntaxKind.ArrowFunction)!\n\t\t\t.getReturnType()\n\t\treturn getProperTypeShape(returnType, parsePropertyAssignment)\n\t}\n\n\t// Import statement\n\tconst importTypeNode = innerLiteralNode\n\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)\n\t\t?.getFirstChildByKind(SyntaxKind.ImportType)\n\tif (importTypeNode) {\n\t\tconst indexOfGreaterThanToken = importTypeNode\n\t\t\t.getLastChildByKind(SyntaxKind.GreaterThanToken)!\n\t\t\t.getChildIndex()\n\t\tconst targetSyntaxList = importTypeNode.getChildAtIndex(indexOfGreaterThanToken - 1)\n\t\treturn getRecursiveNodeShape(targetSyntaxList.getFirstChild()!)\n\t}\n\n\t// Intersection type with Validator\n\tconst intersectionType = innerLiteralNode.isKind(SyntaxKind.IntersectionType)\n\t\t? innerLiteralNode\n\t\t: innerLiteralNode.getParent()?.isKind(SyntaxKind.VariableDeclaration)\n\t\t\t? innerLiteralNode.getParent()?.getFirstChildByKind(SyntaxKind.IntersectionType)\n\t\t\t: null\n\n\tif (intersectionType) {\n\t\tconst validatorType = intersectionType.getFirstChildByKind(SyntaxKind.TypeReference)\n\t\tif (validatorType) {\n\t\t\treturn getTypeReferenceShape(validatorType)\n\t\t}\n\t}\n\n\tconst fileName = innerLiteralNode.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown import type node`)\n\n\treturn 'unknown_2'\n}\n\nexport const getValidatorPropertyOptionality = (node: Node): boolean => {\n\tif (isZodCallExpression(node)) {\n\t\treturn false\n\t}\n\n\tconst callExpressionNode = node.asKind(SyntaxKind.CallExpression)\n\tif (callExpressionNode) {\n\t\tconst identifierNode = callExpressionNode.getFirstChildByKind(SyntaxKind.Identifier)\n\t\tif (identifierNode?.getText() === 'OptionalParam') {\n\t\t\treturn true\n\t\t} else if (identifierNode?.getText() === 'RequiredParam') {\n\t\t\treturn false\n\t\t}\n\n\t\tconst syntaxListNode = callExpressionNode.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\tconst literalExpression = findNodeImplementation(syntaxListNode.getFirstChild()!)\n\t\treturn getValidatorPropertyOptionality(literalExpression)\n\t}\n\n\tconst syntaxListNode = node.getFirstDescendantByKind(SyntaxKind.SyntaxList)!\n\tconst assignmentNodes = syntaxListNode.getChildrenOfKind(SyntaxKind.PropertyAssignment)!\n\n\treturn assignmentNodes.some((node) => {\n\t\tconst identifierNode = node.getFirstDescendantByKind(SyntaxKind.Identifier)!\n\t\tconst identifierName = identifierNode.getText()\n\n\t\tif (identifierName === 'optional') {\n\t\t\tconst value = findPropertyAssignmentValueNode(node)\n\t\t\treturn value.getKind() === SyntaxKind.TrueKeyword\n\t\t}\n\t\treturn false\n\t})\n}\n\nexport const getValidatorPropertyStringValue = (\n\tnodeOrReference: Node,\n\tname: 'description' | 'errorMessage',\n): string => {\n\tif (isZodCallExpression(nodeOrReference)) {\n\t\treturn ''\n\t}\n\n\tconst node = findNodeImplementation(nodeOrReference)\n\n\tconst callExpressionNode = node.asKind(SyntaxKind.CallExpression)\n\tif (callExpressionNode) {\n\t\tconst targetChild = callExpressionNode.getLastChildByKind(SyntaxKind.SyntaxList)!\n\t\treturn getValidatorPropertyStringValue(targetChild, name)\n\t}\n\n\tconst syntaxListNode = node.asKind(SyntaxKind.SyntaxList)\n\tif (syntaxListNode) {\n\t\tconst children = syntaxListNode.getChildren().map((c) => getValidatorPropertyStringValue(c, name))\n\t\treturn children.find((value) => !!value && value !== 'unknown_25') || ''\n\t}\n\n\tconst objectLiteralNode = node.asKind(SyntaxKind.ObjectLiteralExpression)\n\tif (objectLiteralNode) {\n\t\tconst values = getValuesOfObjectLiteral(objectLiteralNode)\n\t\tconst targetValue = values.find((value) => value.identifier === name)\n\t\tif (!targetValue) {\n\t\t\treturn ''\n\t\t}\n\t\tif (Array.isArray(targetValue.value)) {\n\t\t\treturn 'array'\n\t\t}\n\t\treturn targetValue.value || ''\n\t}\n\n\tconst intersectionTypeNode = node.asKind(SyntaxKind.IntersectionType)\n\tif (intersectionTypeNode) {\n\t\treturn (\n\t\t\tintersectionTypeNode\n\t\t\t\t.getTypeNodes()\n\t\t\t\t.flatMap((t) => getValidatorPropertyStringValue(t, name))\n\t\t\t\t.filter((v) => !!v && v !== 'unknown_25')[0] || 'unknown_27'\n\t\t)\n\t}\n\n\tconst typeLiteralNode = node.asKind(SyntaxKind.TypeLiteral)\n\tif (typeLiteralNode) {\n\t\treturn getValidatorPropertyStringValue(typeLiteralNode.getFirstChildByKind(SyntaxKind.SyntaxList)!, name)\n\t}\n\n\tconst propertySignatureNode = node.asKind(SyntaxKind.PropertySignature)\n\tif (propertySignatureNode) {\n\t\tconst identifier = node.getFirstDescendantByKind(SyntaxKind.Identifier)!\n\t\tif (identifier.getText() === name) {\n\t\t\tconst targetNode = findPropertyAssignmentValueNode(propertySignatureNode).getFirstDescendantByKind(\n\t\t\t\tSyntaxKind.StringLiteral,\n\t\t\t)!\n\t\t\treturn targetNode.getLiteralText()\n\t\t}\n\t}\n\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.dev(`[${fileName}] Unknown property string value node ${node.getKindName()}`)\n\treturn 'unknown_25'\n}\n\nconst isPromise = (type: Type) => {\n\tconst symbol = type.getSymbol()\n\tif (!type.isObject() || !symbol) {\n\t\treturn false\n\t}\n\tconst args = type.getTypeArguments()\n\treturn symbol.getName() === 'Promise' && args.length === 1\n}\n\nexport const getProperTypeShape = (\n\ttypeOrPromise: Type,\n\tatLocation: Node,\n\tstack: Type[] = [],\n): ShapeOfType['shape'] => {\n\tconst typeName = typeOrPromise.getAliasSymbol()?.getName()\n\tif (typeName && OpenApiManager.getInstance().hasExposedModel(typeName)) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'ref',\n\t\t\t\tshape: typeName,\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tconst type = isPromise(typeOrPromise) ? typeOrPromise.getTypeArguments()[0] : typeOrPromise\n\n\tif (stack.some((previousType) => previousType === type)) {\n\t\treturn 'circular'\n\t}\n\n\tconst nextStack = stack.concat(type)\n\n\tif (type.getText() === 'void') {\n\t\treturn 'void'\n\t}\n\n\tif (type.isAny()) {\n\t\treturn 'any'\n\t}\n\n\tif (type.isUnknown()) {\n\t\treturn 'unknown'\n\t}\n\n\tif (type.isNull()) {\n\t\treturn 'null'\n\t}\n\n\tif (type.isUndefined()) {\n\t\treturn 'undefined'\n\t}\n\n\tif (type.isBoolean() || type.isBooleanLiteral()) {\n\t\treturn 'boolean'\n\t}\n\n\tif (type.isStringLiteral()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'literal_string' as const,\n\t\t\t\tshape: String(type.getLiteralValue()!),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isNumberLiteral()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'literal_number' as const,\n\t\t\t\tshape: String(type.getLiteralValue()!),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isString() || type.isTemplateLiteral()) {\n\t\treturn 'string'\n\t}\n\n\tif (type.isNumber()) {\n\t\treturn 'number'\n\t}\n\n\tif (type.getText() === 'bigint') {\n\t\treturn 'bigint'\n\t}\n\n\tif (type.isTuple()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'tuple' as const,\n\t\t\t\tshape: type.getTupleElements().map((t) => ({\n\t\t\t\t\trole: 'tuple_entry' as const,\n\t\t\t\t\tshape: getProperTypeShape(t, atLocation, nextStack),\n\t\t\t\t\toptional: false,\n\t\t\t\t})),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isArray()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'array' as const,\n\t\t\t\tshape: getProperTypeShape(type.getArrayElementType()!, atLocation, nextStack),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\t// Handles `interface Foo extends Array<T>` (e.g. Prisma's JsonArray)\n\t// which fails type.isArray() but is still array-like\n\tif (type.isObject()) {\n\t\tconst arrayElementType = type.getNumberIndexType()\n\t\tconst baseTypes = type.getBaseTypes()\n\t\tconst arrayBase = baseTypes?.find((base) => base.isArray())\n\t\tif (arrayBase) {\n\t\t\treturn [\n\t\t\t\t{\n\t\t\t\t\trole: 'array' as const,\n\t\t\t\t\tshape: getProperTypeShape(\n\t\t\t\t\t\tarrayBase.getArrayElementType() ?? arrayElementType!,\n\t\t\t\t\t\tatLocation,\n\t\t\t\t\t\tnextStack,\n\t\t\t\t\t),\n\t\t\t\t\toptional: false,\n\t\t\t\t},\n\t\t\t]\n\t\t}\n\t}\n\n\tconst typeSymbolName = type.getSymbol()?.getName()\n\n\tconst bufferLikeTypes = new Set([\n\t\t'Buffer',\n\t\t'Uint8Array',\n\t\t'Int8Array',\n\t\t'Uint8ClampedArray',\n\t\t'Int16Array',\n\t\t'Uint16Array',\n\t\t'Int32Array',\n\t\t'Uint32Array',\n\t\t'Float32Array',\n\t\t'Float64Array',\n\t\t'BigInt64Array',\n\t\t'BigUint64Array',\n\t\t'ArrayBuffer',\n\t\t'SharedArrayBuffer',\n\t\t'ReadableStream',\n\t])\n\n\tif (type.isObject() && typeSymbolName && bufferLikeTypes.has(typeSymbolName)) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'buffer' as const,\n\t\t\t\tshape: 'buffer',\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isObject() && typeSymbolName === 'RegExp') {\n\t\treturn 'string'\n\t}\n\n\tif (type.isObject() && typeSymbolName === 'Map') {\n\t\tconst typeArgs = type.getTypeArguments()\n\t\tconst valueType = typeArgs[1]\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'record' as const,\n\t\t\t\tshape: valueType ? getProperTypeShape(valueType, atLocation, nextStack) : 'unknown',\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isObject() && typeSymbolName === 'Set') {\n\t\tconst typeArgs = type.getTypeArguments()\n\t\tconst elementType = typeArgs[0]\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'array' as const,\n\t\t\t\tshape: elementType ? getProperTypeShape(elementType, atLocation, nextStack) : 'unknown',\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isObject() && type.getProperties().length === 0) {\n\t\tconst targetType = type.getAliasTypeArguments()[1] ?? type.getStringIndexType()\n\t\tif (targetType) {\n\t\t\treturn [\n\t\t\t\t{\n\t\t\t\t\trole: 'record' as const,\n\t\t\t\t\tshape: getProperTypeShape(targetType, atLocation, nextStack),\n\t\t\t\t\toptional: false,\n\t\t\t\t},\n\t\t\t]\n\t\t}\n\t}\n\n\tif (type.isObject()) {\n\t\tif (typeSymbolName === 'Date' || type.getText() === 'Date') {\n\t\t\treturn 'Date'\n\t\t}\n\t\treturn type\n\t\t\t.getProperties()\n\t\t\t.map((prop) => {\n\t\t\t\tconst valueDeclaration = prop.getValueDeclaration() || prop.getDeclarations()[0]!\n\t\t\t\tif (!valueDeclaration) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\trole: 'property' as const,\n\t\t\t\t\t\tidentifier: prop.getName(),\n\t\t\t\t\t\tshape: getProperTypeShape(prop.getTypeAtLocation(atLocation), atLocation, nextStack),\n\t\t\t\t\t\toptional: false,\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tconst valueDeclarationNode =\n\t\t\t\t\tvalueDeclaration.asKind(SyntaxKind.PropertySignature) ||\n\t\t\t\t\tvalueDeclaration.asKind(SyntaxKind.PropertyAssignment) ||\n\t\t\t\t\tvalueDeclaration.asKind(SyntaxKind.ShorthandPropertyAssignment)\n\n\t\t\t\tif (!valueDeclarationNode) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\trole: 'property' as const,\n\t\t\t\t\t\tidentifier: prop.getName(),\n\t\t\t\t\t\tshape: getProperTypeShape(prop.getTypeAtLocation(atLocation), atLocation, nextStack),\n\t\t\t\t\t\toptional: false,\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst isOptional = prop.getTypeAtLocation(atLocation).isNullable()\n\n\t\t\t\tconst shape = getProperTypeShape(prop.getTypeAtLocation(atLocation), atLocation, nextStack)\n\t\t\t\treturn {\n\t\t\t\t\trole: 'property' as const,\n\t\t\t\t\tidentifier: prop.getName(),\n\t\t\t\t\tshape: shape,\n\t\t\t\t\toptional: isOptional,\n\t\t\t\t}\n\t\t\t})\n\t\t\t.filter((val) => val.shape !== 'undefined')\n\t}\n\n\tif (type.isUnion()) {\n\t\tconst unfilteredShapes: ShapeOfUnionEntry[] = type.getUnionTypes().map((type) => ({\n\t\t\trole: 'union_entry',\n\t\t\tshape: getProperTypeShape(type, atLocation, nextStack),\n\t\t\toptional: false,\n\t\t}))\n\n\t\tconst dedupedShapes = unfilteredShapes.filter(\n\t\t\t(type, index, arr) => !arr.find((dup, dupIndex) => dup.shape === type.shape && dupIndex > index),\n\t\t)\n\t\tconst isNullable = dedupedShapes.some((shape) => shape.shape === 'undefined')\n\t\tconst shapes = dedupedShapes.filter((shape) => shape.shape !== 'undefined')\n\t\tif (shapes.length === 1) {\n\t\t\treturn shapes[0].shape\n\t\t}\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'union',\n\t\t\t\tshape: shapes,\n\t\t\t\toptional: isNullable,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isIntersection()) {\n\t\tconst children = type.getIntersectionTypes()\n\t\tconst shapesOfChildren = children\n\t\t\t.map((child) => getProperTypeShape(child, atLocation, nextStack))\n\t\t\t.filter((shape) => typeof shape !== 'string') as ShapeOfProperty[][]\n\t\treturn shapesOfChildren.reduce<ShapeOfType[]>((total, current) => [...total, ...current], [])\n\t}\n\n\tconst fileName = atLocation.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown type shape node ${typeOrPromise.getText()}`)\n\treturn 'unknown_5'\n}\n\nconst getLiteralValueOfNode = (node: Node): string | string[] | unknown[] => {\n\tif (node.isKind(SyntaxKind.Identifier)) {\n\t\treturn getLiteralValueOfNode(findNodeImplementation(node))\n\t} else if (node.isKind(SyntaxKind.StringLiteral)) {\n\t\treturn node.getLiteralValue()\n\t} else if (node.isKind(SyntaxKind.ArrayLiteralExpression)) {\n\t\treturn node.forEachChildAsArray().map((child) => getLiteralValueOfNode(child)) as string[]\n\t} else if (node.isKind(SyntaxKind.PropertyAccessExpression)) {\n\t\treturn getLiteralValueOfNode(findPropertyAssignmentValueNode(node))\n\t} else if (node.isKind(SyntaxKind.ObjectLiteralExpression)) {\n\t\treturn getValuesOfObjectLiteral(node)\n\t}\n\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.dev(`[${fileName}] Unknown literal value node ${node.getKindName()}`)\n\n\treturn 'unknown_6'\n}\n\nexport const resolveEndpointPath = (node: Node): string | null => {\n\tconst callExpression = node.getFirstDescendantByKind(SyntaxKind.CallExpression)\n\tif (!callExpression) return null\n\n\tconst firstArg = callExpression.getArguments()[0]\n\tif (!firstArg) return null\n\n\tconst argType = firstArg.getType()\n\tif (argType.isStringLiteral()) {\n\t\treturn argType.getLiteralValue() as string\n\t}\n\n\treturn null\n}\n\nexport const getValuesOfObjectLiteral = (objectLiteralNode: Node<ts.ObjectLiteralExpression>) => {\n\tconst syntaxListNode = objectLiteralNode.getFirstDescendantByKind(SyntaxKind.SyntaxList)!\n\tconst assignmentNodes = syntaxListNode.getChildrenOfKind(SyntaxKind.PropertyAssignment)!\n\n\tconst properties = assignmentNodes.map((node) => {\n\t\tconst identifierNode = node.getFirstDescendantByKind(SyntaxKind.Identifier)!\n\t\tconst identifierName = identifierNode.getText()\n\n\t\tconst assignmentValueNode = node.getLastChild()!\n\t\tconst targetNode = findNodeImplementation(assignmentValueNode)\n\t\tconst value = getLiteralValueOfNode(targetNode)\n\n\t\treturn {\n\t\t\tidentifier: identifierName,\n\t\t\tvalue,\n\t\t}\n\t})\n\n\treturn properties || []\n}\n"],"names":["implementationCache","findNodeImplementation","node","cached","SyntaxKind","implementationNode","assignmentValueNode","result","definitionNode","findPropertyAssignmentValueNode","identifierChildren","child","getTypeReferenceShape","firstChild","getRecursiveNodeShape","nodeOrReference","typeName","OpenApiManager","literalNode","typeLiteralNode","propNode","identifier","valueNode","questionMarkToken","typeReferenceNode","lastChild","getProperTypeShape","unionTypeNode","typeQueryNode","qualifiedNameNode","callExpressionNode","awaitExpressionNode","asExpressionNode","fileName","Logger","getShapeOfValidatorLiteral","objectLiteralNode","identifierNode","identifierName","innerLiteralNode","getValidatorPropertyShape","getValidatorPropertyOptionality","getValidatorPropertyStringValue","isZodCallExpression","callExpression","getZodCallShape","objectLiteral","syntaxList","prop","argNode","inlineValidatorAsExpression","typeReference","childTypeReferenceNode","typeNode","childCallExpressionNode","callExpressionArgument","thingyNode","parsePropertyAssignment","returnType","importTypeNode","indexOfGreaterThanToken","targetSyntaxList","intersectionType","validatorType","syntaxListNode","literalExpression","name","targetChild","c","value","targetValue","getValuesOfObjectLiteral","intersectionTypeNode","t","v","propertySignatureNode","isPromise","type","symbol","args","typeOrPromise","atLocation","stack","previousType","nextStack","arrayElementType","arrayBase","base","typeSymbolName","bufferLikeTypes","valueType","elementType","targetType","valueDeclaration","isOptional","shape","val","dedupedShapes","index","arr","dup","dupIndex","isNullable","shapes","total","current","getLiteralValueOfNode","resolveEndpointPath","firstArg","argType","targetNode"],"mappings":"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"}
1
+ {"version":3,"file":"nodeParsers.cjs","sources":["../../../src/openapi/analyzerModule/nodeParsers.ts"],"sourcesContent":["import {\n\tNode,\n\tPropertyAccessExpression,\n\tPropertyAssignment,\n\tPropertySignature,\n\tShorthandPropertyAssignment,\n\tSyntaxKind,\n\tts,\n\tType,\n\tTypeReferenceNode,\n} from 'ts-morph'\n\nimport { Logger } from '../../utils/logger'\nimport { OpenApiManager } from '../manager/OpenApiManager'\nimport { ShapeOfProperty, ShapeOfType, ShapeOfUnionEntry } from './types'\n\nconst implementationCache = new WeakMap<Node, Node>()\n\nexport const findNodeImplementation = (node: Node): Node => {\n\tconst cached = implementationCache.get(node)\n\tif (cached) {\n\t\treturn cached\n\t}\n\n\tif (node.getKind() === SyntaxKind.Identifier) {\n\t\tconst implementationNode = node.asKind(SyntaxKind.Identifier)!.getImplementations()[0]?.getNode()\n\t\tif (implementationNode) {\n\t\t\tconst implementationParentNode = implementationNode.getParent()!\n\t\t\tconst assignmentValueNode = implementationParentNode.getLastChild()!\n\t\t\tif (assignmentValueNode === node) {\n\t\t\t\tthrow new Error('Recursive implementation found')\n\t\t\t}\n\t\t\tconst result = findNodeImplementation(assignmentValueNode)\n\t\t\timplementationCache.set(node, result)\n\t\t\treturn result\n\t\t}\n\n\t\tconst definitionNode = node.asKind(SyntaxKind.Identifier)!.getDefinitions()[0]?.getNode()\n\t\tif (definitionNode) {\n\t\t\tconst definitionParentNode = definitionNode.getParent()!\n\t\t\tconst assignmentValueNode = definitionParentNode.getLastChild()!\n\t\t\tif (assignmentValueNode === node) {\n\t\t\t\tthrow new Error('Recursive implementation found')\n\t\t\t}\n\t\t\tconst result = findNodeImplementation(assignmentValueNode)\n\t\t\timplementationCache.set(node, result)\n\t\t\treturn result\n\t\t}\n\t\tthrow new Error('No implementation nor definition available')\n\t}\n\n\timplementationCache.set(node, node)\n\treturn node\n}\n\nexport const findPropertyAssignmentValueNode = (\n\tnode:\n\t\t| PropertyAssignment\n\t\t| TypeReferenceNode\n\t\t| PropertySignature\n\t\t| PropertyAccessExpression\n\t\t| ShorthandPropertyAssignment,\n): Node => {\n\tconst identifierChildren = node.getChildrenOfKind(SyntaxKind.Identifier)\n\tif (identifierChildren.length === 2) {\n\t\treturn findNodeImplementation(identifierChildren[1])\n\t}\n\tconst lastMatchingChild = node.getChildren().reverse()\n\treturn lastMatchingChild.find(\n\t\t(child) =>\n\t\t\tchild.getKind() !== SyntaxKind.GreaterThanToken &&\n\t\t\tchild.getKind() !== SyntaxKind.CommaToken &&\n\t\t\tchild.getKind() !== SyntaxKind.SemicolonToken,\n\t)!\n}\n\nexport const getTypeReferenceShape = (node: TypeReferenceNode): ShapeOfType['shape'] => {\n\tconst firstChild = node.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\tif (firstChild.isKind(SyntaxKind.SyntaxList)) {\n\t\treturn getRecursiveNodeShape(firstChild.getFirstChild()!)\n\t} else {\n\t\treturn getRecursiveNodeShape(firstChild)\n\t}\n}\n\nexport const getRecursiveNodeShape = (nodeOrReference: Node): ShapeOfType['shape'] => {\n\tconst typeName = nodeOrReference.getSymbol()?.getName()\n\tif (typeName && OpenApiManager.getInstance().hasExposedModel(typeName)) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'ref',\n\t\t\t\tshape: typeName,\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tconst node = findNodeImplementation(nodeOrReference)\n\n\t// Undefined\n\tconst undefinedNode = node.asKind(SyntaxKind.UndefinedKeyword)\n\tif (undefinedNode) {\n\t\treturn 'undefined'\n\t}\n\n\t// Literal type\n\tconst literalNode = node.asKind(SyntaxKind.LiteralType)\n\tif (literalNode) {\n\t\tif (literalNode.getFirstChildByKind(SyntaxKind.TrueKeyword)) {\n\t\t\treturn 'true'\n\t\t}\n\t\tif (literalNode.getFirstChildByKind(SyntaxKind.FalseKeyword)) {\n\t\t\treturn 'false'\n\t\t}\n\t}\n\n\t// Boolean literal\n\tconst booleanLiteralNode =\n\t\tnode.asKind(SyntaxKind.BooleanKeyword) ||\n\t\tnode.asKind(SyntaxKind.TrueKeyword) ||\n\t\tnode.asKind(SyntaxKind.FalseKeyword)\n\tif (booleanLiteralNode) {\n\t\treturn 'boolean'\n\t}\n\n\t// String literal\n\tconst stringLiteralNode = node.asKind(SyntaxKind.StringKeyword) || node.asKind(SyntaxKind.StringLiteral)\n\tif (stringLiteralNode) {\n\t\treturn 'string'\n\t}\n\n\t// Number literal\n\tconst numberLiteralNode = node.asKind(SyntaxKind.NumberKeyword) || node.asKind(SyntaxKind.NumericLiteral)\n\tif (numberLiteralNode) {\n\t\treturn 'number'\n\t}\n\n\t// BigInt literal\n\tconst bigIntNode = node.asKind(SyntaxKind.BigIntKeyword) || node.asKind(SyntaxKind.BigIntLiteral)\n\tif (bigIntNode) {\n\t\treturn 'bigint'\n\t}\n\n\t// Type literal\n\tconst typeLiteralNode = node.asKind(SyntaxKind.TypeLiteral)\n\tif (typeLiteralNode) {\n\t\tconst properties = typeLiteralNode\n\t\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\t\t.getChildrenOfKind(SyntaxKind.PropertySignature)\n\n\t\tconst propertyShapes = properties.map((propNode) => {\n\t\t\tconst identifier = propNode.getFirstChildByKind(SyntaxKind.Identifier)!\n\t\t\tconst valueNode = findPropertyAssignmentValueNode(propNode)\n\t\t\tconst questionMarkToken = identifier.getNextSiblingIfKind(SyntaxKind.QuestionToken)\n\t\t\treturn {\n\t\t\t\trole: 'property' as const,\n\t\t\t\tidentifier: identifier.getText(),\n\t\t\t\tshape: getRecursiveNodeShape(valueNode),\n\t\t\t\toptional: valueNode.getType().isNullable() || !!questionMarkToken,\n\t\t\t}\n\t\t})\n\t\treturn propertyShapes\n\t}\n\n\t// Type reference\n\tconst typeReferenceNode = node.asKind(SyntaxKind.TypeReference)\n\tif (typeReferenceNode) {\n\t\treturn getRecursiveNodeShape(typeReferenceNode.getFirstChild()!)\n\t}\n\n\t// Property access expression\n\tconst propertyAccessNode = node.asKind(SyntaxKind.PropertyAccessExpression)\n\tif (propertyAccessNode) {\n\t\tconst lastChild = findNodeImplementation(node.getLastChild()!)\n\t\treturn getProperTypeShape(lastChild.asKind(SyntaxKind.CallExpression)!.getReturnType(), lastChild)\n\t}\n\n\t// Union type\n\tconst unionTypeNode = node.asKind(SyntaxKind.UnionType)\n\tif (unionTypeNode) {\n\t\treturn getProperTypeShape(unionTypeNode.getType(), node)\n\t}\n\n\t// Typeof query\n\tconst typeQueryNode = node.asKind(SyntaxKind.TypeQuery)\n\tif (typeQueryNode) {\n\t\treturn getRecursiveNodeShape(typeQueryNode.getLastChild()!)\n\t}\n\n\t// Qualified name\n\tconst qualifiedNameNode = node.asKind(SyntaxKind.QualifiedName)\n\tif (qualifiedNameNode) {\n\t\treturn getRecursiveNodeShape(qualifiedNameNode.getLastChild()!)\n\t}\n\n\t// Call expression\n\tconst callExpressionNode = node.asKind(SyntaxKind.CallExpression)\n\tif (callExpressionNode) {\n\t\treturn getProperTypeShape(callExpressionNode.getReturnType(), callExpressionNode)\n\t}\n\n\t// Await expression\n\tconst awaitExpressionNode = node.asKind(SyntaxKind.AwaitExpression)\n\tif (awaitExpressionNode) {\n\t\treturn getRecursiveNodeShape(awaitExpressionNode.getChildAtIndex(1)!)\n\t}\n\n\t// 'As' Expression\n\tconst asExpressionNode = node.asKind(SyntaxKind.AsExpression)\n\tif (asExpressionNode) {\n\t\treturn getRecursiveNodeShape(asExpressionNode.getChildAtIndex(2)!)\n\t}\n\n\t// TODO\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown node type: ${node.getKindName()}`)\n\treturn 'unknown_1'\n}\n\nexport const getShapeOfValidatorLiteral = (\n\tobjectLiteralNode: Node<ts.ObjectLiteralExpression>,\n): (ShapeOfProperty & { description: string; errorMessage: string })[] => {\n\tconst syntaxListNode = objectLiteralNode.getFirstDescendantByKind(SyntaxKind.SyntaxList)!\n\tconst assignmentNodes = syntaxListNode.getChildrenOfKind(SyntaxKind.PropertyAssignment)!\n\n\tconst properties = assignmentNodes.map((node) => {\n\t\tconst identifierNode = node.getFirstChild()!\n\t\tconst identifierName = (() => {\n\t\t\tif (identifierNode.isKind(SyntaxKind.Identifier)) {\n\t\t\t\treturn identifierNode.getText()\n\t\t\t}\n\t\t\tif (identifierNode.isKind(SyntaxKind.StringLiteral)) {\n\t\t\t\treturn identifierNode.getLiteralText()\n\t\t\t}\n\t\t\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\t\t\tLogger.warn(`[${fileName}] Unknown identifier name: ${identifierNode.getText()}`)\n\t\t\treturn 'unknown_30'\n\t\t})()\n\n\t\tconst assignmentValueNode = node.getLastChild()!\n\t\tconst innerLiteralNode = findNodeImplementation(assignmentValueNode)\n\n\t\treturn {\n\t\t\trole: 'property' as const,\n\t\t\tidentifier: identifierName,\n\t\t\tshape: getValidatorPropertyShape(innerLiteralNode),\n\t\t\toptional: getValidatorPropertyOptionality(innerLiteralNode),\n\t\t\tdescription: getValidatorPropertyStringValue(innerLiteralNode, 'description'),\n\t\t\terrorMessage: getValidatorPropertyStringValue(innerLiteralNode, 'errorMessage'),\n\t\t}\n\t})\n\n\treturn properties || []\n}\n\nconst isZodCallExpression = (node: Node): boolean => {\n\tconst callExpression = node.asKind(SyntaxKind.CallExpression)\n\tif (!callExpression) {\n\t\treturn false\n\t}\n\tconst returnType = callExpression.getReturnType()\n\tconst typeName = returnType.getSymbol()?.getName() ?? ''\n\treturn typeName.startsWith('Zod')\n}\n\nconst getZodCallShape = (node: Node): ShapeOfType['shape'] => {\n\tconst callExpression = node.asKind(SyntaxKind.CallExpression)!\n\tconst returnType = callExpression.getReturnType()\n\tconst typeName = returnType.getSymbol()?.getName() ?? ''\n\n\tif (typeName === 'ZodNumber') {\n\t\treturn 'number'\n\t}\n\tif (typeName === 'ZodString') {\n\t\treturn 'string'\n\t}\n\tif (typeName === 'ZodBoolean') {\n\t\treturn 'boolean'\n\t}\n\tif (typeName === 'ZodBigInt') {\n\t\treturn 'bigint'\n\t}\n\n\tif (typeName === 'ZodObject') {\n\t\tconst argNode = callExpression.getFirstChildByKind(SyntaxKind.SyntaxList)?.getFirstChild()\n\t\tconst objectLiteral = argNode?.asKind(SyntaxKind.ObjectLiteralExpression)\n\t\tif (!objectLiteral) {\n\t\t\treturn 'unknown_zod_object'\n\t\t}\n\t\tconst syntaxList = objectLiteral.getFirstChildByKind(SyntaxKind.SyntaxList)\n\t\tif (!syntaxList) {\n\t\t\treturn []\n\t\t}\n\t\tconst properties = syntaxList.getChildrenOfKind(SyntaxKind.PropertyAssignment)\n\t\treturn properties.map((prop) => {\n\t\t\tconst identifier = prop.getFirstChildByKind(SyntaxKind.Identifier)!.getText()\n\t\t\tconst valueNode = prop.getLastChild()!\n\t\t\treturn {\n\t\t\t\trole: 'property' as const,\n\t\t\t\tidentifier,\n\t\t\t\tshape: isZodCallExpression(valueNode)\n\t\t\t\t\t? getZodCallShape(valueNode)\n\t\t\t\t\t: getValidatorPropertyShape(valueNode),\n\t\t\t\toptional: false,\n\t\t\t}\n\t\t})\n\t}\n\n\tif (typeName === 'ZodArray') {\n\t\tconst argNode = callExpression.getFirstChildByKind(SyntaxKind.SyntaxList)?.getFirstChild()\n\t\tif (!argNode) {\n\t\t\treturn 'unknown_zod_array'\n\t\t}\n\t\tconst elementShape = isZodCallExpression(argNode)\n\t\t\t? getZodCallShape(argNode)\n\t\t\t: getValidatorPropertyShape(argNode)\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'array' as const,\n\t\t\t\tshape: elementShape,\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (typeName === 'ZodEnum') {\n\t\tconst typeArgs = returnType.getTypeArguments()\n\t\tif (typeArgs.length > 0) {\n\t\t\tconst enumType = typeArgs[0]\n\t\t\tconst properties = enumType.getProperties()\n\t\t\tconst shapes: ShapeOfUnionEntry[] = properties.map((prop) => ({\n\t\t\t\trole: 'union_entry' as const,\n\t\t\t\tshape: getProperTypeShape(prop.getTypeAtLocation(callExpression), callExpression, []),\n\t\t\t\toptional: false,\n\t\t\t}))\n\t\t\tif (shapes.length === 1) {\n\t\t\t\treturn shapes[0].shape\n\t\t\t}\n\t\t\tif (shapes.length > 1) {\n\t\t\t\treturn [\n\t\t\t\t\t{\n\t\t\t\t\t\trole: 'union' as const,\n\t\t\t\t\t\tshape: shapes,\n\t\t\t\t\t\toptional: false,\n\t\t\t\t\t},\n\t\t\t\t]\n\t\t\t}\n\t\t}\n\t\treturn 'unknown_zod_enum'\n\t}\n\n\tif (typeName === 'ZodOptional') {\n\t\tconst innerCallExpression = callExpression\n\t\t\t.getFirstChildByKind(SyntaxKind.PropertyAccessExpression)\n\t\t\t?.getFirstChildByKind(SyntaxKind.CallExpression)\n\t\tif (innerCallExpression && isZodCallExpression(innerCallExpression)) {\n\t\t\treturn getZodCallShape(innerCallExpression)\n\t\t}\n\t\treturn 'unknown_zod_optional'\n\t}\n\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown zod type: ${typeName}`)\n\treturn 'unknown_zod'\n}\n\nexport const getValidatorPropertyShape = (innerLiteralNode: Node): ShapeOfType['shape'] => {\n\t// Zod validator (e.g. z.number(), z.string(), z.object({...}), z.array(...))\n\tif (isZodCallExpression(innerLiteralNode)) {\n\t\treturn getZodCallShape(innerLiteralNode)\n\t}\n\n\t// Inline definition with `as Validator<...>` clause\n\tconst inlineValidatorAsExpression = innerLiteralNode\n\t\t.getParent()!\n\t\t.getFirstChildByKind(SyntaxKind.AsExpression)\n\tif (inlineValidatorAsExpression) {\n\t\tconst typeReference = inlineValidatorAsExpression.getLastChildByKind(SyntaxKind.TypeReference)!\n\t\treturn getTypeReferenceShape(typeReference)\n\t}\n\n\t// Variable with `: Validator<...>` clause\n\tconst childTypeReferenceNode = innerLiteralNode.getParent()!.getFirstChildByKind(SyntaxKind.TypeReference)\n\tif (childTypeReferenceNode) {\n\t\treturn getTypeReferenceShape(childTypeReferenceNode)\n\t}\n\n\t// `RequiredParam<...>` inline call expression\n\tif (innerLiteralNode.getParent()!.getChildrenOfKind(SyntaxKind.SyntaxList).length >= 2) {\n\t\tconst typeNode = innerLiteralNode\n\t\t\t.getParent()!\n\t\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\t\t.getFirstChild()!\n\t\treturn getRecursiveNodeShape(typeNode)\n\t}\n\n\t// `RequestParam | RequiredParam | OptionalParam` call expression\n\tconst childCallExpressionNode = innerLiteralNode.getParent()!.getFirstChildByKind(SyntaxKind.CallExpression)\n\tif (childCallExpressionNode) {\n\t\tconst callExpressionArgument = findNodeImplementation(\n\t\t\tchildCallExpressionNode.getFirstChildByKind(SyntaxKind.SyntaxList)!.getFirstChild()!,\n\t\t)\n\n\t\t// Param is a type reference\n\t\tconst typeReferenceNode = callExpressionArgument\n\t\t\t.getParent()!\n\t\t\t.getFirstChildByKind(SyntaxKind.TypeReference)!\n\t\tif (typeReferenceNode) {\n\t\t\treturn getProperTypeShape(typeReferenceNode.getType(), typeReferenceNode, [])\n\t\t}\n\n\t\tconst thingyNode = callExpressionArgument\n\t\t\t.getParent()!\n\t\t\t.getFirstChildByKind(SyntaxKind.ObjectLiteralExpression)!\n\t\tif (thingyNode) {\n\t\t\treturn getValidatorPropertyShape(thingyNode)\n\t\t}\n\n\t\tif (callExpressionArgument.getKind() === SyntaxKind.CallExpression) {\n\t\t\treturn getValidatorPropertyShape(callExpressionArgument)\n\t\t}\n\n\t\tif (callExpressionArgument.getKind() === SyntaxKind.IntersectionType) {\n\t\t\treturn getValidatorPropertyShape(callExpressionArgument)\n\t\t}\n\n\t\tconst fileName = innerLiteralNode.getSourceFile().getFilePath().split('/').pop()\n\t\tLogger.warn(`[${fileName}] Unknown call expression argument: ${callExpressionArgument.getKindName()}`)\n\t\treturn 'unknown_3'\n\t}\n\n\t// Attempting to infer type from `parse` function\n\tconst innerNodePropertyAssignments = innerLiteralNode\n\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\t.getChildrenOfKind(SyntaxKind.PropertyAssignment)\n\tconst parsePropertyAssignment = innerNodePropertyAssignments.find((prop) => {\n\t\treturn prop.getFirstChildByKind(SyntaxKind.Identifier)?.getText() === 'parse'\n\t})\n\tif (parsePropertyAssignment) {\n\t\tconst returnType = findPropertyAssignmentValueNode(parsePropertyAssignment)\n\t\t\t.asKind(SyntaxKind.ArrowFunction)!\n\t\t\t.getReturnType()\n\t\treturn getProperTypeShape(returnType, parsePropertyAssignment)\n\t}\n\n\t// Import statement\n\tconst importTypeNode = innerLiteralNode\n\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)\n\t\t?.getFirstChildByKind(SyntaxKind.ImportType)\n\tif (importTypeNode) {\n\t\tconst indexOfGreaterThanToken = importTypeNode\n\t\t\t.getLastChildByKind(SyntaxKind.GreaterThanToken)!\n\t\t\t.getChildIndex()\n\t\tconst targetSyntaxList = importTypeNode.getChildAtIndex(indexOfGreaterThanToken - 1)\n\t\treturn getRecursiveNodeShape(targetSyntaxList.getFirstChild()!)\n\t}\n\n\t// Intersection type with Validator\n\tconst intersectionType = innerLiteralNode.isKind(SyntaxKind.IntersectionType)\n\t\t? innerLiteralNode\n\t\t: innerLiteralNode.getParent()?.isKind(SyntaxKind.VariableDeclaration)\n\t\t\t? innerLiteralNode.getParent()?.getFirstChildByKind(SyntaxKind.IntersectionType)\n\t\t\t: null\n\n\tif (intersectionType) {\n\t\tconst validatorType = intersectionType.getFirstChildByKind(SyntaxKind.TypeReference)\n\t\tif (validatorType) {\n\t\t\treturn getTypeReferenceShape(validatorType)\n\t\t}\n\t}\n\n\tconst fileName = innerLiteralNode.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown import type node`)\n\n\treturn 'unknown_2'\n}\n\nexport const getValidatorPropertyOptionality = (node: Node): boolean => {\n\tif (isZodCallExpression(node)) {\n\t\tconst callExpression = node.asKind(SyntaxKind.CallExpression)!\n\t\tconst returnType = callExpression.getReturnType()\n\t\tconst typeName = returnType.getSymbol()?.getName() ?? ''\n\t\tif (typeName === 'ZodOptional') {\n\t\t\treturn true\n\t\t}\n\t\treturn false\n\t}\n\n\tconst callExpressionNode = node.asKind(SyntaxKind.CallExpression)\n\tif (callExpressionNode) {\n\t\tconst identifierNode = callExpressionNode.getFirstChildByKind(SyntaxKind.Identifier)\n\t\tif (identifierNode?.getText() === 'OptionalParam') {\n\t\t\treturn true\n\t\t} else if (identifierNode?.getText() === 'RequiredParam') {\n\t\t\treturn false\n\t\t}\n\n\t\tconst syntaxListNode = callExpressionNode.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\tconst literalExpression = findNodeImplementation(syntaxListNode.getFirstChild()!)\n\t\treturn getValidatorPropertyOptionality(literalExpression)\n\t}\n\n\tconst syntaxListNode = node.getFirstDescendantByKind(SyntaxKind.SyntaxList)!\n\tconst assignmentNodes = syntaxListNode.getChildrenOfKind(SyntaxKind.PropertyAssignment)!\n\n\treturn assignmentNodes.some((node) => {\n\t\tconst identifierNode = node.getFirstDescendantByKind(SyntaxKind.Identifier)!\n\t\tconst identifierName = identifierNode.getText()\n\n\t\tif (identifierName === 'optional') {\n\t\t\tconst value = findPropertyAssignmentValueNode(node)\n\t\t\treturn value.getKind() === SyntaxKind.TrueKeyword\n\t\t}\n\t\treturn false\n\t})\n}\n\nexport const getValidatorPropertyStringValue = (\n\tnodeOrReference: Node,\n\tname: 'description' | 'errorMessage',\n): string => {\n\tif (isZodCallExpression(nodeOrReference)) {\n\t\treturn ''\n\t}\n\n\tconst node = findNodeImplementation(nodeOrReference)\n\n\tconst callExpressionNode = node.asKind(SyntaxKind.CallExpression)\n\tif (callExpressionNode) {\n\t\tconst targetChild = callExpressionNode.getLastChildByKind(SyntaxKind.SyntaxList)!\n\t\treturn getValidatorPropertyStringValue(targetChild, name)\n\t}\n\n\tconst syntaxListNode = node.asKind(SyntaxKind.SyntaxList)\n\tif (syntaxListNode) {\n\t\tconst children = syntaxListNode.getChildren().map((c) => getValidatorPropertyStringValue(c, name))\n\t\treturn children.find((value) => !!value && value !== 'unknown_25') || ''\n\t}\n\n\tconst objectLiteralNode = node.asKind(SyntaxKind.ObjectLiteralExpression)\n\tif (objectLiteralNode) {\n\t\tconst values = getValuesOfObjectLiteral(objectLiteralNode)\n\t\tconst targetValue = values.find((value) => value.identifier === name)\n\t\tif (!targetValue) {\n\t\t\treturn ''\n\t\t}\n\t\tif (Array.isArray(targetValue.value)) {\n\t\t\treturn 'array'\n\t\t}\n\t\treturn targetValue.value || ''\n\t}\n\n\tconst intersectionTypeNode = node.asKind(SyntaxKind.IntersectionType)\n\tif (intersectionTypeNode) {\n\t\treturn (\n\t\t\tintersectionTypeNode\n\t\t\t\t.getTypeNodes()\n\t\t\t\t.flatMap((t) => getValidatorPropertyStringValue(t, name))\n\t\t\t\t.filter((v) => !!v && v !== 'unknown_25')[0] || 'unknown_27'\n\t\t)\n\t}\n\n\tconst typeLiteralNode = node.asKind(SyntaxKind.TypeLiteral)\n\tif (typeLiteralNode) {\n\t\treturn getValidatorPropertyStringValue(typeLiteralNode.getFirstChildByKind(SyntaxKind.SyntaxList)!, name)\n\t}\n\n\tconst propertySignatureNode = node.asKind(SyntaxKind.PropertySignature)\n\tif (propertySignatureNode) {\n\t\tconst identifier = node.getFirstDescendantByKind(SyntaxKind.Identifier)!\n\t\tif (identifier.getText() === name) {\n\t\t\tconst targetNode = findPropertyAssignmentValueNode(propertySignatureNode).getFirstDescendantByKind(\n\t\t\t\tSyntaxKind.StringLiteral,\n\t\t\t)!\n\t\t\treturn targetNode.getLiteralText()\n\t\t}\n\t}\n\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.dev(`[${fileName}] Unknown property string value node ${node.getKindName()}`)\n\treturn 'unknown_25'\n}\n\nconst isPromise = (type: Type) => {\n\tconst symbol = type.getSymbol()\n\tif (!type.isObject() || !symbol) {\n\t\treturn false\n\t}\n\tconst args = type.getTypeArguments()\n\treturn symbol.getName() === 'Promise' && args.length === 1\n}\n\nexport const getProperTypeShape = (\n\ttypeOrPromise: Type,\n\tatLocation: Node,\n\tstack: Type[] = [],\n): ShapeOfType['shape'] => {\n\tconst typeName = typeOrPromise.getAliasSymbol()?.getName()\n\tif (typeName && OpenApiManager.getInstance().hasExposedModel(typeName)) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'ref',\n\t\t\t\tshape: typeName,\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tconst type = isPromise(typeOrPromise) ? typeOrPromise.getTypeArguments()[0] : typeOrPromise\n\n\tif (stack.some((previousType) => previousType === type)) {\n\t\treturn 'circular'\n\t}\n\n\tconst nextStack = stack.concat(type)\n\n\tif (type.getText() === 'void') {\n\t\treturn 'void'\n\t}\n\n\tif (type.isAny()) {\n\t\treturn 'any'\n\t}\n\n\tif (type.isUnknown()) {\n\t\treturn 'unknown'\n\t}\n\n\tif (type.isNull()) {\n\t\treturn 'null'\n\t}\n\n\tif (type.isUndefined()) {\n\t\treturn 'undefined'\n\t}\n\n\tif (type.isBoolean() || type.isBooleanLiteral()) {\n\t\treturn 'boolean'\n\t}\n\n\tif (type.isStringLiteral()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'literal_string' as const,\n\t\t\t\tshape: String(type.getLiteralValue()!),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isNumberLiteral()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'literal_number' as const,\n\t\t\t\tshape: String(type.getLiteralValue()!),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isString() || type.isTemplateLiteral()) {\n\t\treturn 'string'\n\t}\n\n\tif (type.isNumber()) {\n\t\treturn 'number'\n\t}\n\n\tif (type.getText() === 'bigint') {\n\t\treturn 'bigint'\n\t}\n\n\tif (type.isTuple()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'tuple' as const,\n\t\t\t\tshape: type.getTupleElements().map((t) => ({\n\t\t\t\t\trole: 'tuple_entry' as const,\n\t\t\t\t\tshape: getProperTypeShape(t, atLocation, nextStack),\n\t\t\t\t\toptional: false,\n\t\t\t\t})),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isArray()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'array' as const,\n\t\t\t\tshape: getProperTypeShape(type.getArrayElementType()!, atLocation, nextStack),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\t// Handles `interface Foo extends Array<T>` (e.g. Prisma's JsonArray)\n\t// which fails type.isArray() but is still array-like\n\tif (type.isObject()) {\n\t\tconst arrayElementType = type.getNumberIndexType()\n\t\tconst baseTypes = type.getBaseTypes()\n\t\tconst arrayBase = baseTypes?.find((base) => base.isArray())\n\t\tif (arrayBase) {\n\t\t\treturn [\n\t\t\t\t{\n\t\t\t\t\trole: 'array' as const,\n\t\t\t\t\tshape: getProperTypeShape(\n\t\t\t\t\t\tarrayBase.getArrayElementType() ?? arrayElementType!,\n\t\t\t\t\t\tatLocation,\n\t\t\t\t\t\tnextStack,\n\t\t\t\t\t),\n\t\t\t\t\toptional: false,\n\t\t\t\t},\n\t\t\t]\n\t\t}\n\t}\n\n\tconst typeSymbolName = type.getSymbol()?.getName()\n\n\tconst bufferLikeTypes = new Set([\n\t\t'Buffer',\n\t\t'Uint8Array',\n\t\t'Int8Array',\n\t\t'Uint8ClampedArray',\n\t\t'Int16Array',\n\t\t'Uint16Array',\n\t\t'Int32Array',\n\t\t'Uint32Array',\n\t\t'Float32Array',\n\t\t'Float64Array',\n\t\t'BigInt64Array',\n\t\t'BigUint64Array',\n\t\t'ArrayBuffer',\n\t\t'SharedArrayBuffer',\n\t\t'ReadableStream',\n\t])\n\n\tif (type.isObject() && typeSymbolName && bufferLikeTypes.has(typeSymbolName)) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'buffer' as const,\n\t\t\t\tshape: 'buffer',\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isObject() && typeSymbolName === 'RegExp') {\n\t\treturn 'string'\n\t}\n\n\tif (type.isObject() && typeSymbolName === 'Map') {\n\t\tconst typeArgs = type.getTypeArguments()\n\t\tconst valueType = typeArgs[1]\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'record' as const,\n\t\t\t\tshape: valueType ? getProperTypeShape(valueType, atLocation, nextStack) : 'unknown',\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isObject() && typeSymbolName === 'Set') {\n\t\tconst typeArgs = type.getTypeArguments()\n\t\tconst elementType = typeArgs[0]\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'array' as const,\n\t\t\t\tshape: elementType ? getProperTypeShape(elementType, atLocation, nextStack) : 'unknown',\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isObject() && type.getProperties().length === 0) {\n\t\tconst targetType = type.getAliasTypeArguments()[1] ?? type.getStringIndexType()\n\t\tif (targetType) {\n\t\t\treturn [\n\t\t\t\t{\n\t\t\t\t\trole: 'record' as const,\n\t\t\t\t\tshape: getProperTypeShape(targetType, atLocation, nextStack),\n\t\t\t\t\toptional: false,\n\t\t\t\t},\n\t\t\t]\n\t\t}\n\t}\n\n\tif (type.isObject()) {\n\t\tif (typeSymbolName === 'Date' || type.getText() === 'Date') {\n\t\t\treturn 'Date'\n\t\t}\n\t\treturn type\n\t\t\t.getProperties()\n\t\t\t.map((prop) => {\n\t\t\t\tconst valueDeclaration = prop.getValueDeclaration() || prop.getDeclarations()[0]!\n\t\t\t\tif (!valueDeclaration) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\trole: 'property' as const,\n\t\t\t\t\t\tidentifier: prop.getName(),\n\t\t\t\t\t\tshape: getProperTypeShape(prop.getTypeAtLocation(atLocation), atLocation, nextStack),\n\t\t\t\t\t\toptional: false,\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tconst valueDeclarationNode =\n\t\t\t\t\tvalueDeclaration.asKind(SyntaxKind.PropertySignature) ||\n\t\t\t\t\tvalueDeclaration.asKind(SyntaxKind.PropertyAssignment) ||\n\t\t\t\t\tvalueDeclaration.asKind(SyntaxKind.ShorthandPropertyAssignment)\n\n\t\t\t\tif (!valueDeclarationNode) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\trole: 'property' as const,\n\t\t\t\t\t\tidentifier: prop.getName(),\n\t\t\t\t\t\tshape: getProperTypeShape(prop.getTypeAtLocation(atLocation), atLocation, nextStack),\n\t\t\t\t\t\toptional: false,\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst isOptional = prop.getTypeAtLocation(atLocation).isNullable()\n\n\t\t\t\tconst shape = getProperTypeShape(prop.getTypeAtLocation(atLocation), atLocation, nextStack)\n\t\t\t\treturn {\n\t\t\t\t\trole: 'property' as const,\n\t\t\t\t\tidentifier: prop.getName(),\n\t\t\t\t\tshape: shape,\n\t\t\t\t\toptional: isOptional,\n\t\t\t\t}\n\t\t\t})\n\t\t\t.filter((val) => val.shape !== 'undefined')\n\t}\n\n\tif (type.isUnion()) {\n\t\tconst unfilteredShapes: ShapeOfUnionEntry[] = type.getUnionTypes().map((type) => ({\n\t\t\trole: 'union_entry',\n\t\t\tshape: getProperTypeShape(type, atLocation, nextStack),\n\t\t\toptional: false,\n\t\t}))\n\n\t\tconst dedupedShapes = unfilteredShapes.filter(\n\t\t\t(type, index, arr) => !arr.find((dup, dupIndex) => dup.shape === type.shape && dupIndex > index),\n\t\t)\n\t\tconst isNullable = dedupedShapes.some((shape) => shape.shape === 'undefined')\n\t\tconst shapes = dedupedShapes.filter((shape) => shape.shape !== 'undefined')\n\t\tif (shapes.length === 1) {\n\t\t\treturn shapes[0].shape\n\t\t}\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'union',\n\t\t\t\tshape: shapes,\n\t\t\t\toptional: isNullable,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isIntersection()) {\n\t\tconst children = type.getIntersectionTypes()\n\t\tconst shapesOfChildren = children\n\t\t\t.map((child) => getProperTypeShape(child, atLocation, nextStack))\n\t\t\t.filter((shape) => typeof shape !== 'string') as ShapeOfProperty[][]\n\t\treturn shapesOfChildren.reduce<ShapeOfType[]>((total, current) => [...total, ...current], [])\n\t}\n\n\tconst fileName = atLocation.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown type shape node ${typeOrPromise.getText()}`)\n\treturn 'unknown_5'\n}\n\nconst getLiteralValueOfNode = (node: Node): string | string[] | unknown[] => {\n\tif (node.isKind(SyntaxKind.Identifier)) {\n\t\treturn getLiteralValueOfNode(findNodeImplementation(node))\n\t} else if (node.isKind(SyntaxKind.StringLiteral)) {\n\t\treturn node.getLiteralValue()\n\t} else if (node.isKind(SyntaxKind.ArrayLiteralExpression)) {\n\t\treturn node.forEachChildAsArray().map((child) => getLiteralValueOfNode(child)) as string[]\n\t} else if (node.isKind(SyntaxKind.PropertyAccessExpression)) {\n\t\treturn getLiteralValueOfNode(findPropertyAssignmentValueNode(node))\n\t} else if (node.isKind(SyntaxKind.ObjectLiteralExpression)) {\n\t\treturn getValuesOfObjectLiteral(node)\n\t}\n\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.dev(`[${fileName}] Unknown literal value node ${node.getKindName()}`)\n\n\treturn 'unknown_6'\n}\n\nexport const resolveEndpointPath = (node: Node): string | null => {\n\tconst callExpression = node.getFirstDescendantByKind(SyntaxKind.CallExpression)\n\tif (!callExpression) return null\n\n\tconst firstArg = callExpression.getArguments()[0]\n\tif (!firstArg) return null\n\n\tconst argType = firstArg.getType()\n\tif (argType.isStringLiteral()) {\n\t\treturn argType.getLiteralValue() as string\n\t}\n\n\treturn null\n}\n\nexport const getValuesOfObjectLiteral = (objectLiteralNode: Node<ts.ObjectLiteralExpression>) => {\n\tconst syntaxListNode = objectLiteralNode.getFirstDescendantByKind(SyntaxKind.SyntaxList)!\n\tconst assignmentNodes = syntaxListNode.getChildrenOfKind(SyntaxKind.PropertyAssignment)!\n\n\tconst properties = assignmentNodes.map((node) => {\n\t\tconst identifierNode = node.getFirstDescendantByKind(SyntaxKind.Identifier)!\n\t\tconst identifierName = identifierNode.getText()\n\n\t\tconst assignmentValueNode = node.getLastChild()!\n\t\tconst targetNode = findNodeImplementation(assignmentValueNode)\n\t\tconst value = getLiteralValueOfNode(targetNode)\n\n\t\treturn {\n\t\t\tidentifier: identifierName,\n\t\t\tvalue,\n\t\t}\n\t})\n\n\treturn properties || []\n}\n"],"names":["implementationCache","findNodeImplementation","node","cached","SyntaxKind","implementationNode","assignmentValueNode","result","definitionNode","findPropertyAssignmentValueNode","identifierChildren","child","getTypeReferenceShape","firstChild","getRecursiveNodeShape","nodeOrReference","typeName","OpenApiManager","literalNode","typeLiteralNode","propNode","identifier","valueNode","questionMarkToken","typeReferenceNode","lastChild","getProperTypeShape","unionTypeNode","typeQueryNode","qualifiedNameNode","callExpressionNode","awaitExpressionNode","asExpressionNode","fileName","Logger","getShapeOfValidatorLiteral","objectLiteralNode","identifierNode","identifierName","innerLiteralNode","getValidatorPropertyShape","getValidatorPropertyOptionality","getValidatorPropertyStringValue","isZodCallExpression","callExpression","getZodCallShape","returnType","objectLiteral","syntaxList","prop","argNode","typeArgs","shapes","innerCallExpression","inlineValidatorAsExpression","typeReference","childTypeReferenceNode","typeNode","childCallExpressionNode","callExpressionArgument","thingyNode","parsePropertyAssignment","importTypeNode","indexOfGreaterThanToken","targetSyntaxList","intersectionType","validatorType","syntaxListNode","literalExpression","name","targetChild","c","value","targetValue","getValuesOfObjectLiteral","intersectionTypeNode","t","v","propertySignatureNode","isPromise","type","symbol","args","typeOrPromise","atLocation","stack","previousType","nextStack","arrayElementType","arrayBase","base","typeSymbolName","bufferLikeTypes","valueType","elementType","targetType","valueDeclaration","isOptional","shape","val","dedupedShapes","index","arr","dup","dupIndex","isNullable","total","current","getLiteralValueOfNode","resolveEndpointPath","firstArg","argType","targetNode"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"nodeParsers.d.ts","sourceRoot":"","sources":["../../../src/openapi/analyzerModule/nodeParsers.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,IAAI,EACJ,wBAAwB,EACxB,kBAAkB,EAClB,iBAAiB,EACjB,2BAA2B,EAE3B,EAAE,EACF,IAAI,EACJ,iBAAiB,EACjB,MAAM,UAAU,CAAA;AAIjB,OAAO,EAAE,eAAe,EAAE,WAAW,EAAqB,MAAM,SAAS,CAAA;AAIzE,eAAO,MAAM,sBAAsB,SAAU,IAAI,KAAG,IAmCnD,CAAA;AAED,eAAO,MAAM,+BAA+B,SAExC,kBAAkB,GAClB,iBAAiB,GACjB,iBAAiB,GACjB,wBAAwB,GACxB,2BAA2B,KAC5B,IAYF,CAAA;AAED,eAAO,MAAM,qBAAqB,SAAU,iBAAiB,KAAG,WAAW,CAAC,OAAO,CAOlF,CAAA;AAED,eAAO,MAAM,qBAAqB,oBAAqB,IAAI,KAAG,WAAW,CAAC,OAAO,CAoIhF,CAAA;AAED,eAAO,MAAM,0BAA0B,sBACnB,IAAI,CAAC,EAAE,CAAC,uBAAuB,CAAC,KACjD,CAAC,eAAe,GAAG;IAAE,WAAW,EAAE,MAAM,CAAC;IAAC,YAAY,EAAE,MAAM,CAAA;CAAE,CAAC,EAgCnE,CAAA;AA6ED,eAAO,MAAM,yBAAyB,qBAAsB,IAAI,KAAG,WAAW,CAAC,OAAO,CA6GrF,CAAA;AAED,eAAO,MAAM,+BAA+B,SAAU,IAAI,KAAG,OAgC5D,CAAA;AAED,eAAO,MAAM,+BAA+B,oBAC1B,IAAI,QACf,aAAa,GAAG,cAAc,KAClC,MA6DF,CAAA;AAWD,eAAO,MAAM,kBAAkB,kBACf,IAAI,cACP,IAAI,UACT,IAAI,EAAE,KACX,WAAW,CAAC,OAAO,CA8QrB,CAAA;AAqBD,eAAO,MAAM,mBAAmB,SAAU,IAAI,KAAG,MAAM,GAAG,IAazD,CAAA;AAED,eAAO,MAAM,wBAAwB,sBAAuB,IAAI,CAAC,EAAE,CAAC,uBAAuB,CAAC;;;GAmB3F,CAAA"}
1
+ {"version":3,"file":"nodeParsers.d.ts","sourceRoot":"","sources":["../../../src/openapi/analyzerModule/nodeParsers.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,IAAI,EACJ,wBAAwB,EACxB,kBAAkB,EAClB,iBAAiB,EACjB,2BAA2B,EAE3B,EAAE,EACF,IAAI,EACJ,iBAAiB,EACjB,MAAM,UAAU,CAAA;AAIjB,OAAO,EAAE,eAAe,EAAE,WAAW,EAAqB,MAAM,SAAS,CAAA;AAIzE,eAAO,MAAM,sBAAsB,SAAU,IAAI,KAAG,IAmCnD,CAAA;AAED,eAAO,MAAM,+BAA+B,SAExC,kBAAkB,GAClB,iBAAiB,GACjB,iBAAiB,GACjB,wBAAwB,GACxB,2BAA2B,KAC5B,IAYF,CAAA;AAED,eAAO,MAAM,qBAAqB,SAAU,iBAAiB,KAAG,WAAW,CAAC,OAAO,CAOlF,CAAA;AAED,eAAO,MAAM,qBAAqB,oBAAqB,IAAI,KAAG,WAAW,CAAC,OAAO,CAoIhF,CAAA;AAED,eAAO,MAAM,0BAA0B,sBACnB,IAAI,CAAC,EAAE,CAAC,uBAAuB,CAAC,KACjD,CAAC,eAAe,GAAG;IAAE,WAAW,EAAE,MAAM,CAAC;IAAC,YAAY,EAAE,MAAM,CAAA;CAAE,CAAC,EAgCnE,CAAA;AAiHD,eAAO,MAAM,yBAAyB,qBAAsB,IAAI,KAAG,WAAW,CAAC,OAAO,CA6GrF,CAAA;AAED,eAAO,MAAM,+BAA+B,SAAU,IAAI,KAAG,OAsC5D,CAAA;AAED,eAAO,MAAM,+BAA+B,oBAC1B,IAAI,QACf,aAAa,GAAG,cAAc,KAClC,MA6DF,CAAA;AAWD,eAAO,MAAM,kBAAkB,kBACf,IAAI,cACP,IAAI,UACT,IAAI,EAAE,KACX,WAAW,CAAC,OAAO,CA8QrB,CAAA;AAqBD,eAAO,MAAM,mBAAmB,SAAU,IAAI,KAAG,MAAM,GAAG,IAazD,CAAA;AAED,eAAO,MAAM,wBAAwB,sBAAuB,IAAI,CAAC,EAAE,CAAC,uBAAuB,CAAC;;;GAmB3F,CAAA"}
@@ -64,41 +64,41 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
64
64
  const r = s.asKind(e.TypeLiteral);
65
65
  if (r)
66
66
  return r.getFirstChildByKind(e.SyntaxList).getChildrenOfKind(e.PropertySignature).map((I) => {
67
- const k = I.getFirstChildByKind(e.Identifier), O = S(I), _ = k.getNextSiblingIfKind(e.QuestionToken);
67
+ const k = I.getFirstChildByKind(e.Identifier), O = S(I), U = k.getNextSiblingIfKind(e.QuestionToken);
68
68
  return {
69
69
  role: "property",
70
70
  identifier: k.getText(),
71
71
  shape: m(O),
72
- optional: O.getType().isNullable() || !!_
72
+ optional: O.getType().isNullable() || !!U
73
73
  };
74
74
  });
75
75
  const a = s.asKind(e.TypeReference);
76
76
  if (a)
77
77
  return m(a.getFirstChild());
78
78
  if (s.asKind(e.PropertyAccessExpression)) {
79
- const B = h(s.getLastChild());
80
- return f(B.asKind(e.CallExpression).getReturnType(), B);
79
+ const E = h(s.getLastChild());
80
+ return f(E.asKind(e.CallExpression).getReturnType(), E);
81
81
  }
82
- const u = s.asKind(e.UnionType);
83
- if (u)
84
- return f(u.getType(), s);
82
+ const c = s.asKind(e.UnionType);
83
+ if (c)
84
+ return f(c.getType(), s);
85
85
  const y = s.asKind(e.TypeQuery);
86
86
  if (y)
87
87
  return m(y.getLastChild());
88
88
  const A = s.asKind(e.QualifiedName);
89
89
  if (A)
90
90
  return m(A.getLastChild());
91
- const x = s.asKind(e.CallExpression);
92
- if (x)
93
- return f(x.getReturnType(), x);
91
+ const C = s.asKind(e.CallExpression);
92
+ if (C)
93
+ return f(C.getReturnType(), C);
94
94
  const F = s.asKind(e.AwaitExpression);
95
95
  if (F)
96
96
  return m(F.getChildAtIndex(1));
97
97
  const b = s.asKind(e.AsExpression);
98
98
  if (b)
99
99
  return m(b.getChildAtIndex(2));
100
- const U = s.getSourceFile().getFilePath().split("/").pop();
101
- return K.warn(`[${U}] Unknown node type: ${s.getKindName()}`), "unknown_1";
100
+ const V = s.getSourceFile().getFilePath().split("/").pop();
101
+ return K.warn(`[${V}] Unknown node type: ${s.getKindName()}`), "unknown_1";
102
102
  }, z = (t) => t.getFirstDescendantByKind(e.SyntaxList).getChildrenOfKind(e.PropertyAssignment).map((n) => {
103
103
  const o = n.getFirstChild(), d = (() => {
104
104
  if (o.isKind(e.Identifier))
@@ -107,20 +107,20 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
107
107
  return o.getLiteralText();
108
108
  const r = n.getSourceFile().getFilePath().split("/").pop();
109
109
  return K.warn(`[${r}] Unknown identifier name: ${o.getText()}`), "unknown_30";
110
- })(), g = n.getLastChild(), c = h(g);
110
+ })(), u = n.getLastChild(), g = h(u);
111
111
  return {
112
112
  role: "property",
113
113
  identifier: d,
114
- shape: T(c),
115
- optional: V(c),
116
- description: N(c, "description"),
117
- errorMessage: N(c, "errorMessage")
114
+ shape: x(g),
115
+ optional: _(g),
116
+ description: N(g, "description"),
117
+ errorMessage: N(g, "errorMessage")
118
118
  };
119
- }) || [], C = (t) => {
119
+ }) || [], T = (t) => {
120
120
  const i = t.asKind(e.CallExpression);
121
121
  return i ? (i.getReturnType().getSymbol()?.getName() ?? "").startsWith("Zod") : !1;
122
- }, E = (t) => {
123
- const i = t.asKind(e.CallExpression), l = i.getReturnType().getSymbol()?.getName() ?? "";
122
+ }, w = (t) => {
123
+ const i = t.asKind(e.CallExpression), s = i.getReturnType(), l = s.getSymbol()?.getName() ?? "";
124
124
  if (l === "ZodNumber")
125
125
  return "number";
126
126
  if (l === "ZodString")
@@ -133,13 +133,13 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
133
133
  const d = i.getFirstChildByKind(e.SyntaxList)?.getFirstChild()?.asKind(e.ObjectLiteralExpression);
134
134
  if (!d)
135
135
  return "unknown_zod_object";
136
- const g = d.getFirstChildByKind(e.SyntaxList);
137
- return g ? g.getChildrenOfKind(e.PropertyAssignment).map((r) => {
136
+ const u = d.getFirstChildByKind(e.SyntaxList);
137
+ return u ? u.getChildrenOfKind(e.PropertyAssignment).map((r) => {
138
138
  const a = r.getFirstChildByKind(e.Identifier).getText(), p = r.getLastChild();
139
139
  return {
140
140
  role: "property",
141
141
  identifier: a,
142
- shape: C(p) ? E(p) : T(p),
142
+ shape: T(p) ? w(p) : x(p),
143
143
  optional: !1
144
144
  };
145
145
  }) : [];
@@ -149,16 +149,41 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
149
149
  return o ? [
150
150
  {
151
151
  role: "array",
152
- shape: C(o) ? E(o) : T(o),
152
+ shape: T(o) ? w(o) : x(o),
153
153
  optional: !1
154
154
  }
155
155
  ] : "unknown_zod_array";
156
156
  }
157
+ if (l === "ZodEnum") {
158
+ const o = s.getTypeArguments();
159
+ if (o.length > 0) {
160
+ const g = o[0].getProperties().map((r) => ({
161
+ role: "union_entry",
162
+ shape: f(r.getTypeAtLocation(i), i, []),
163
+ optional: !1
164
+ }));
165
+ if (g.length === 1)
166
+ return g[0].shape;
167
+ if (g.length > 1)
168
+ return [
169
+ {
170
+ role: "union",
171
+ shape: g,
172
+ optional: !1
173
+ }
174
+ ];
175
+ }
176
+ return "unknown_zod_enum";
177
+ }
178
+ if (l === "ZodOptional") {
179
+ const o = i.getFirstChildByKind(e.PropertyAccessExpression)?.getFirstChildByKind(e.CallExpression);
180
+ return o && T(o) ? w(o) : "unknown_zod_optional";
181
+ }
157
182
  const n = t.getSourceFile().getFilePath().split("/").pop();
158
183
  return K.warn(`[${n}] Unknown zod type: ${l}`), "unknown_zod";
159
- }, T = (t) => {
160
- if (C(t))
161
- return E(t);
184
+ }, x = (t) => {
185
+ if (T(t))
186
+ return w(t);
162
187
  const i = t.getParent().getFirstChildByKind(e.AsExpression);
163
188
  if (i) {
164
189
  const r = i.getLastChildByKind(e.TypeReference);
@@ -180,11 +205,11 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
180
205
  return f(a.getType(), a, []);
181
206
  const p = r.getParent().getFirstChildByKind(e.ObjectLiteralExpression);
182
207
  if (p)
183
- return T(p);
208
+ return x(p);
184
209
  if (r.getKind() === e.CallExpression || r.getKind() === e.IntersectionType)
185
- return T(r);
186
- const u = t.getSourceFile().getFilePath().split("/").pop();
187
- return K.warn(`[${u}] Unknown call expression argument: ${r.getKindName()}`), "unknown_3";
210
+ return x(r);
211
+ const c = t.getSourceFile().getFilePath().split("/").pop();
212
+ return K.warn(`[${c}] Unknown call expression argument: ${r.getKindName()}`), "unknown_3";
188
213
  }
189
214
  const o = t.getFirstChildByKind(e.SyntaxList).getChildrenOfKind(e.PropertyAssignment).find((r) => r.getFirstChildByKind(e.Identifier)?.getText() === "parse");
190
215
  if (o) {
@@ -196,17 +221,17 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
196
221
  const r = d.getLastChildByKind(e.GreaterThanToken).getChildIndex(), a = d.getChildAtIndex(r - 1);
197
222
  return m(a.getFirstChild());
198
223
  }
199
- const g = t.isKind(e.IntersectionType) ? t : t.getParent()?.isKind(e.VariableDeclaration) ? t.getParent()?.getFirstChildByKind(e.IntersectionType) : null;
200
- if (g) {
201
- const r = g.getFirstChildByKind(e.TypeReference);
224
+ const u = t.isKind(e.IntersectionType) ? t : t.getParent()?.isKind(e.VariableDeclaration) ? t.getParent()?.getFirstChildByKind(e.IntersectionType) : null;
225
+ if (u) {
226
+ const r = u.getFirstChildByKind(e.TypeReference);
202
227
  if (r)
203
228
  return P(r);
204
229
  }
205
- const c = t.getSourceFile().getFilePath().split("/").pop();
206
- return K.warn(`[${c}] Unknown import type node`), "unknown_2";
207
- }, V = (t) => {
208
- if (C(t))
209
- return !1;
230
+ const g = t.getSourceFile().getFilePath().split("/").pop();
231
+ return K.warn(`[${g}] Unknown import type node`), "unknown_2";
232
+ }, _ = (t) => {
233
+ if (T(t))
234
+ return (t.asKind(e.CallExpression).getReturnType().getSymbol()?.getName() ?? "") === "ZodOptional";
210
235
  const i = t.asKind(e.CallExpression);
211
236
  if (i) {
212
237
  const n = i.getFirstChildByKind(e.Identifier);
@@ -215,11 +240,11 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
215
240
  if (n?.getText() === "RequiredParam")
216
241
  return !1;
217
242
  const o = i.getFirstChildByKind(e.SyntaxList), d = h(o.getFirstChild());
218
- return V(d);
243
+ return _(d);
219
244
  }
220
245
  return t.getFirstDescendantByKind(e.SyntaxList).getChildrenOfKind(e.PropertyAssignment).some((n) => n.getFirstDescendantByKind(e.Identifier).getText() === "optional" ? S(n).getKind() === e.TrueKeyword : !1);
221
246
  }, N = (t, i) => {
222
- if (C(t))
247
+ if (T(t))
223
248
  return "";
224
249
  const s = h(t), l = s.asKind(e.CallExpression);
225
250
  if (l) {
@@ -231,18 +256,18 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
231
256
  return n.getChildren().map((p) => N(p, i)).find((p) => !!p && p !== "unknown_25") || "";
232
257
  const o = s.asKind(e.ObjectLiteralExpression);
233
258
  if (o) {
234
- const p = R(o).find((u) => u.identifier === i);
259
+ const p = R(o).find((c) => c.identifier === i);
235
260
  return p ? Array.isArray(p.value) ? "array" : p.value || "" : "";
236
261
  }
237
262
  const d = s.asKind(e.IntersectionType);
238
263
  if (d)
239
264
  return d.getTypeNodes().flatMap((a) => N(a, i)).filter((a) => !!a && a !== "unknown_25")[0] || "unknown_27";
240
- const g = s.asKind(e.TypeLiteral);
241
- if (g)
242
- return N(g.getFirstChildByKind(e.SyntaxList), i);
243
- const c = s.asKind(e.PropertySignature);
244
- if (c && s.getFirstDescendantByKind(e.Identifier).getText() === i)
245
- return S(c).getFirstDescendantByKind(
265
+ const u = s.asKind(e.TypeLiteral);
266
+ if (u)
267
+ return N(u.getFirstChildByKind(e.SyntaxList), i);
268
+ const g = s.asKind(e.PropertySignature);
269
+ if (g && s.getFirstDescendantByKind(e.Identifier).getText() === i)
270
+ return S(g).getFirstDescendantByKind(
246
271
  e.StringLiteral
247
272
  ).getLiteralText();
248
273
  const r = s.getSourceFile().getFilePath().split("/").pop();
@@ -322,7 +347,7 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
322
347
  }
323
348
  ];
324
349
  if (n.isObject()) {
325
- const r = n.getNumberIndexType(), p = n.getBaseTypes()?.find((u) => u.isArray());
350
+ const r = n.getNumberIndexType(), p = n.getBaseTypes()?.find((c) => c.isArray());
326
351
  if (p)
327
352
  return [
328
353
  {
@@ -336,7 +361,7 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
336
361
  }
337
362
  ];
338
363
  }
339
- const d = n.getSymbol()?.getName(), g = /* @__PURE__ */ new Set([
364
+ const d = n.getSymbol()?.getName(), u = /* @__PURE__ */ new Set([
340
365
  "Buffer",
341
366
  "Uint8Array",
342
367
  "Int8Array",
@@ -353,7 +378,7 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
353
378
  "SharedArrayBuffer",
354
379
  "ReadableStream"
355
380
  ]);
356
- if (n.isObject() && d && g.has(d))
381
+ if (n.isObject() && d && u.has(d))
357
382
  return [
358
383
  {
359
384
  role: "buffer",
@@ -411,12 +436,12 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
411
436
  shape: f(r.getTypeAtLocation(i), i, o),
412
437
  optional: !1
413
438
  };
414
- const u = r.getTypeAtLocation(i).isNullable(), y = f(r.getTypeAtLocation(i), i, o);
439
+ const c = r.getTypeAtLocation(i).isNullable(), y = f(r.getTypeAtLocation(i), i, o);
415
440
  return {
416
441
  role: "property",
417
442
  identifier: r.getName(),
418
443
  shape: y,
419
- optional: u
444
+ optional: c
420
445
  };
421
446
  }).filter((r) => r.shape !== "undefined");
422
447
  if (n.isUnion()) {
@@ -425,29 +450,29 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
425
450
  shape: f(y, i, o),
426
451
  optional: !1
427
452
  })).filter(
428
- (y, A, x) => !x.find((F, b) => F.shape === y.shape && b > A)
429
- ), p = a.some((y) => y.shape === "undefined"), u = a.filter((y) => y.shape !== "undefined");
430
- return u.length === 1 ? u[0].shape : [
453
+ (y, A, C) => !C.find((F, b) => F.shape === y.shape && b > A)
454
+ ), p = a.some((y) => y.shape === "undefined"), c = a.filter((y) => y.shape !== "undefined");
455
+ return c.length === 1 ? c[0].shape : [
431
456
  {
432
457
  role: "union",
433
- shape: u,
458
+ shape: c,
434
459
  optional: p
435
460
  }
436
461
  ];
437
462
  }
438
463
  if (n.isIntersection())
439
- return n.getIntersectionTypes().map((p) => f(p, i, o)).filter((p) => typeof p != "string").reduce((p, u) => [...p, ...u], []);
440
- const c = i.getSourceFile().getFilePath().split("/").pop();
441
- return K.warn(`[${c}] Unknown type shape node ${t.getText()}`), "unknown_5";
442
- }, w = (t) => {
464
+ return n.getIntersectionTypes().map((p) => f(p, i, o)).filter((p) => typeof p != "string").reduce((p, c) => [...p, ...c], []);
465
+ const g = i.getSourceFile().getFilePath().split("/").pop();
466
+ return K.warn(`[${g}] Unknown type shape node ${t.getText()}`), "unknown_5";
467
+ }, B = (t) => {
443
468
  if (t.isKind(e.Identifier))
444
- return w(h(t));
469
+ return B(h(t));
445
470
  if (t.isKind(e.StringLiteral))
446
471
  return t.getLiteralValue();
447
472
  if (t.isKind(e.ArrayLiteralExpression))
448
- return t.forEachChildAsArray().map((s) => w(s));
473
+ return t.forEachChildAsArray().map((s) => B(s));
449
474
  if (t.isKind(e.PropertyAccessExpression))
450
- return w(S(t));
475
+ return B(S(t));
451
476
  if (t.isKind(e.ObjectLiteralExpression))
452
477
  return R(t);
453
478
  const i = t.getSourceFile().getFilePath().split("/").pop();
@@ -460,7 +485,7 @@ const L = /* @__PURE__ */ new WeakMap(), h = (t) => {
460
485
  const l = s.getType();
461
486
  return l.isStringLiteral() ? l.getLiteralValue() : null;
462
487
  }, R = (t) => t.getFirstDescendantByKind(e.SyntaxList).getChildrenOfKind(e.PropertyAssignment).map((n) => {
463
- const d = n.getFirstDescendantByKind(e.Identifier).getText(), g = n.getLastChild(), c = h(g), r = w(c);
488
+ const d = n.getFirstDescendantByKind(e.Identifier).getText(), u = n.getLastChild(), g = h(u), r = B(g);
464
489
  return {
465
490
  identifier: d,
466
491
  value: r
@@ -473,8 +498,8 @@ export {
473
498
  m as getRecursiveNodeShape,
474
499
  z as getShapeOfValidatorLiteral,
475
500
  P as getTypeReferenceShape,
476
- V as getValidatorPropertyOptionality,
477
- T as getValidatorPropertyShape,
501
+ _ as getValidatorPropertyOptionality,
502
+ x as getValidatorPropertyShape,
478
503
  N as getValidatorPropertyStringValue,
479
504
  R as getValuesOfObjectLiteral,
480
505
  Q as resolveEndpointPath
@@ -1 +1 @@
1
- {"version":3,"file":"nodeParsers.mjs","sources":["../../../src/openapi/analyzerModule/nodeParsers.ts"],"sourcesContent":["import {\n\tNode,\n\tPropertyAccessExpression,\n\tPropertyAssignment,\n\tPropertySignature,\n\tShorthandPropertyAssignment,\n\tSyntaxKind,\n\tts,\n\tType,\n\tTypeReferenceNode,\n} from 'ts-morph'\n\nimport { Logger } from '../../utils/logger'\nimport { OpenApiManager } from '../manager/OpenApiManager'\nimport { ShapeOfProperty, ShapeOfType, ShapeOfUnionEntry } from './types'\n\nconst implementationCache = new WeakMap<Node, Node>()\n\nexport const findNodeImplementation = (node: Node): Node => {\n\tconst cached = implementationCache.get(node)\n\tif (cached) {\n\t\treturn cached\n\t}\n\n\tif (node.getKind() === SyntaxKind.Identifier) {\n\t\tconst implementationNode = node.asKind(SyntaxKind.Identifier)!.getImplementations()[0]?.getNode()\n\t\tif (implementationNode) {\n\t\t\tconst implementationParentNode = implementationNode.getParent()!\n\t\t\tconst assignmentValueNode = implementationParentNode.getLastChild()!\n\t\t\tif (assignmentValueNode === node) {\n\t\t\t\tthrow new Error('Recursive implementation found')\n\t\t\t}\n\t\t\tconst result = findNodeImplementation(assignmentValueNode)\n\t\t\timplementationCache.set(node, result)\n\t\t\treturn result\n\t\t}\n\n\t\tconst definitionNode = node.asKind(SyntaxKind.Identifier)!.getDefinitions()[0]?.getNode()\n\t\tif (definitionNode) {\n\t\t\tconst definitionParentNode = definitionNode.getParent()!\n\t\t\tconst assignmentValueNode = definitionParentNode.getLastChild()!\n\t\t\tif (assignmentValueNode === node) {\n\t\t\t\tthrow new Error('Recursive implementation found')\n\t\t\t}\n\t\t\tconst result = findNodeImplementation(assignmentValueNode)\n\t\t\timplementationCache.set(node, result)\n\t\t\treturn result\n\t\t}\n\t\tthrow new Error('No implementation nor definition available')\n\t}\n\n\timplementationCache.set(node, node)\n\treturn node\n}\n\nexport const findPropertyAssignmentValueNode = (\n\tnode:\n\t\t| PropertyAssignment\n\t\t| TypeReferenceNode\n\t\t| PropertySignature\n\t\t| PropertyAccessExpression\n\t\t| ShorthandPropertyAssignment,\n): Node => {\n\tconst identifierChildren = node.getChildrenOfKind(SyntaxKind.Identifier)\n\tif (identifierChildren.length === 2) {\n\t\treturn findNodeImplementation(identifierChildren[1])\n\t}\n\tconst lastMatchingChild = node.getChildren().reverse()\n\treturn lastMatchingChild.find(\n\t\t(child) =>\n\t\t\tchild.getKind() !== SyntaxKind.GreaterThanToken &&\n\t\t\tchild.getKind() !== SyntaxKind.CommaToken &&\n\t\t\tchild.getKind() !== SyntaxKind.SemicolonToken,\n\t)!\n}\n\nexport const getTypeReferenceShape = (node: TypeReferenceNode): ShapeOfType['shape'] => {\n\tconst firstChild = node.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\tif (firstChild.isKind(SyntaxKind.SyntaxList)) {\n\t\treturn getRecursiveNodeShape(firstChild.getFirstChild()!)\n\t} else {\n\t\treturn getRecursiveNodeShape(firstChild)\n\t}\n}\n\nexport const getRecursiveNodeShape = (nodeOrReference: Node): ShapeOfType['shape'] => {\n\tconst typeName = nodeOrReference.getSymbol()?.getName()\n\tif (typeName && OpenApiManager.getInstance().hasExposedModel(typeName)) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'ref',\n\t\t\t\tshape: typeName,\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tconst node = findNodeImplementation(nodeOrReference)\n\n\t// Undefined\n\tconst undefinedNode = node.asKind(SyntaxKind.UndefinedKeyword)\n\tif (undefinedNode) {\n\t\treturn 'undefined'\n\t}\n\n\t// Literal type\n\tconst literalNode = node.asKind(SyntaxKind.LiteralType)\n\tif (literalNode) {\n\t\tif (literalNode.getFirstChildByKind(SyntaxKind.TrueKeyword)) {\n\t\t\treturn 'true'\n\t\t}\n\t\tif (literalNode.getFirstChildByKind(SyntaxKind.FalseKeyword)) {\n\t\t\treturn 'false'\n\t\t}\n\t}\n\n\t// Boolean literal\n\tconst booleanLiteralNode =\n\t\tnode.asKind(SyntaxKind.BooleanKeyword) ||\n\t\tnode.asKind(SyntaxKind.TrueKeyword) ||\n\t\tnode.asKind(SyntaxKind.FalseKeyword)\n\tif (booleanLiteralNode) {\n\t\treturn 'boolean'\n\t}\n\n\t// String literal\n\tconst stringLiteralNode = node.asKind(SyntaxKind.StringKeyword) || node.asKind(SyntaxKind.StringLiteral)\n\tif (stringLiteralNode) {\n\t\treturn 'string'\n\t}\n\n\t// Number literal\n\tconst numberLiteralNode = node.asKind(SyntaxKind.NumberKeyword) || node.asKind(SyntaxKind.NumericLiteral)\n\tif (numberLiteralNode) {\n\t\treturn 'number'\n\t}\n\n\t// BigInt literal\n\tconst bigIntNode = node.asKind(SyntaxKind.BigIntKeyword) || node.asKind(SyntaxKind.BigIntLiteral)\n\tif (bigIntNode) {\n\t\treturn 'bigint'\n\t}\n\n\t// Type literal\n\tconst typeLiteralNode = node.asKind(SyntaxKind.TypeLiteral)\n\tif (typeLiteralNode) {\n\t\tconst properties = typeLiteralNode\n\t\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\t\t.getChildrenOfKind(SyntaxKind.PropertySignature)\n\n\t\tconst propertyShapes = properties.map((propNode) => {\n\t\t\tconst identifier = propNode.getFirstChildByKind(SyntaxKind.Identifier)!\n\t\t\tconst valueNode = findPropertyAssignmentValueNode(propNode)\n\t\t\tconst questionMarkToken = identifier.getNextSiblingIfKind(SyntaxKind.QuestionToken)\n\t\t\treturn {\n\t\t\t\trole: 'property' as const,\n\t\t\t\tidentifier: identifier.getText(),\n\t\t\t\tshape: getRecursiveNodeShape(valueNode),\n\t\t\t\toptional: valueNode.getType().isNullable() || !!questionMarkToken,\n\t\t\t}\n\t\t})\n\t\treturn propertyShapes\n\t}\n\n\t// Type reference\n\tconst typeReferenceNode = node.asKind(SyntaxKind.TypeReference)\n\tif (typeReferenceNode) {\n\t\treturn getRecursiveNodeShape(typeReferenceNode.getFirstChild()!)\n\t}\n\n\t// Property access expression\n\tconst propertyAccessNode = node.asKind(SyntaxKind.PropertyAccessExpression)\n\tif (propertyAccessNode) {\n\t\tconst lastChild = findNodeImplementation(node.getLastChild()!)\n\t\treturn getProperTypeShape(lastChild.asKind(SyntaxKind.CallExpression)!.getReturnType(), lastChild)\n\t}\n\n\t// Union type\n\tconst unionTypeNode = node.asKind(SyntaxKind.UnionType)\n\tif (unionTypeNode) {\n\t\treturn getProperTypeShape(unionTypeNode.getType(), node)\n\t}\n\n\t// Typeof query\n\tconst typeQueryNode = node.asKind(SyntaxKind.TypeQuery)\n\tif (typeQueryNode) {\n\t\treturn getRecursiveNodeShape(typeQueryNode.getLastChild()!)\n\t}\n\n\t// Qualified name\n\tconst qualifiedNameNode = node.asKind(SyntaxKind.QualifiedName)\n\tif (qualifiedNameNode) {\n\t\treturn getRecursiveNodeShape(qualifiedNameNode.getLastChild()!)\n\t}\n\n\t// Call expression\n\tconst callExpressionNode = node.asKind(SyntaxKind.CallExpression)\n\tif (callExpressionNode) {\n\t\treturn getProperTypeShape(callExpressionNode.getReturnType(), callExpressionNode)\n\t}\n\n\t// Await expression\n\tconst awaitExpressionNode = node.asKind(SyntaxKind.AwaitExpression)\n\tif (awaitExpressionNode) {\n\t\treturn getRecursiveNodeShape(awaitExpressionNode.getChildAtIndex(1)!)\n\t}\n\n\t// 'As' Expression\n\tconst asExpressionNode = node.asKind(SyntaxKind.AsExpression)\n\tif (asExpressionNode) {\n\t\treturn getRecursiveNodeShape(asExpressionNode.getChildAtIndex(2)!)\n\t}\n\n\t// TODO\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown node type: ${node.getKindName()}`)\n\treturn 'unknown_1'\n}\n\nexport const getShapeOfValidatorLiteral = (\n\tobjectLiteralNode: Node<ts.ObjectLiteralExpression>,\n): (ShapeOfProperty & { description: string; errorMessage: string })[] => {\n\tconst syntaxListNode = objectLiteralNode.getFirstDescendantByKind(SyntaxKind.SyntaxList)!\n\tconst assignmentNodes = syntaxListNode.getChildrenOfKind(SyntaxKind.PropertyAssignment)!\n\n\tconst properties = assignmentNodes.map((node) => {\n\t\tconst identifierNode = node.getFirstChild()!\n\t\tconst identifierName = (() => {\n\t\t\tif (identifierNode.isKind(SyntaxKind.Identifier)) {\n\t\t\t\treturn identifierNode.getText()\n\t\t\t}\n\t\t\tif (identifierNode.isKind(SyntaxKind.StringLiteral)) {\n\t\t\t\treturn identifierNode.getLiteralText()\n\t\t\t}\n\t\t\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\t\t\tLogger.warn(`[${fileName}] Unknown identifier name: ${identifierNode.getText()}`)\n\t\t\treturn 'unknown_30'\n\t\t})()\n\n\t\tconst assignmentValueNode = node.getLastChild()!\n\t\tconst innerLiteralNode = findNodeImplementation(assignmentValueNode)\n\n\t\treturn {\n\t\t\trole: 'property' as const,\n\t\t\tidentifier: identifierName,\n\t\t\tshape: getValidatorPropertyShape(innerLiteralNode),\n\t\t\toptional: getValidatorPropertyOptionality(innerLiteralNode),\n\t\t\tdescription: getValidatorPropertyStringValue(innerLiteralNode, 'description'),\n\t\t\terrorMessage: getValidatorPropertyStringValue(innerLiteralNode, 'errorMessage'),\n\t\t}\n\t})\n\n\treturn properties || []\n}\n\nconst isZodCallExpression = (node: Node): boolean => {\n\tconst callExpression = node.asKind(SyntaxKind.CallExpression)\n\tif (!callExpression) {\n\t\treturn false\n\t}\n\tconst returnType = callExpression.getReturnType()\n\tconst typeName = returnType.getSymbol()?.getName() ?? ''\n\treturn typeName.startsWith('Zod')\n}\n\nconst getZodCallShape = (node: Node): ShapeOfType['shape'] => {\n\tconst callExpression = node.asKind(SyntaxKind.CallExpression)!\n\tconst returnType = callExpression.getReturnType()\n\tconst typeName = returnType.getSymbol()?.getName() ?? ''\n\n\tif (typeName === 'ZodNumber') {\n\t\treturn 'number'\n\t}\n\tif (typeName === 'ZodString') {\n\t\treturn 'string'\n\t}\n\tif (typeName === 'ZodBoolean') {\n\t\treturn 'boolean'\n\t}\n\tif (typeName === 'ZodBigInt') {\n\t\treturn 'bigint'\n\t}\n\n\tif (typeName === 'ZodObject') {\n\t\tconst argNode = callExpression.getFirstChildByKind(SyntaxKind.SyntaxList)?.getFirstChild()\n\t\tconst objectLiteral = argNode?.asKind(SyntaxKind.ObjectLiteralExpression)\n\t\tif (!objectLiteral) {\n\t\t\treturn 'unknown_zod_object'\n\t\t}\n\t\tconst syntaxList = objectLiteral.getFirstChildByKind(SyntaxKind.SyntaxList)\n\t\tif (!syntaxList) {\n\t\t\treturn []\n\t\t}\n\t\tconst properties = syntaxList.getChildrenOfKind(SyntaxKind.PropertyAssignment)\n\t\treturn properties.map((prop) => {\n\t\t\tconst identifier = prop.getFirstChildByKind(SyntaxKind.Identifier)!.getText()\n\t\t\tconst valueNode = prop.getLastChild()!\n\t\t\treturn {\n\t\t\t\trole: 'property' as const,\n\t\t\t\tidentifier,\n\t\t\t\tshape: isZodCallExpression(valueNode)\n\t\t\t\t\t? getZodCallShape(valueNode)\n\t\t\t\t\t: getValidatorPropertyShape(valueNode),\n\t\t\t\toptional: false,\n\t\t\t}\n\t\t})\n\t}\n\n\tif (typeName === 'ZodArray') {\n\t\tconst argNode = callExpression.getFirstChildByKind(SyntaxKind.SyntaxList)?.getFirstChild()\n\t\tif (!argNode) {\n\t\t\treturn 'unknown_zod_array'\n\t\t}\n\t\tconst elementShape = isZodCallExpression(argNode)\n\t\t\t? getZodCallShape(argNode)\n\t\t\t: getValidatorPropertyShape(argNode)\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'array' as const,\n\t\t\t\tshape: elementShape,\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown zod type: ${typeName}`)\n\treturn 'unknown_zod'\n}\n\nexport const getValidatorPropertyShape = (innerLiteralNode: Node): ShapeOfType['shape'] => {\n\t// Zod validator (e.g. z.number(), z.string(), z.object({...}), z.array(...))\n\tif (isZodCallExpression(innerLiteralNode)) {\n\t\treturn getZodCallShape(innerLiteralNode)\n\t}\n\n\t// Inline definition with `as Validator<...>` clause\n\tconst inlineValidatorAsExpression = innerLiteralNode\n\t\t.getParent()!\n\t\t.getFirstChildByKind(SyntaxKind.AsExpression)\n\tif (inlineValidatorAsExpression) {\n\t\tconst typeReference = inlineValidatorAsExpression.getLastChildByKind(SyntaxKind.TypeReference)!\n\t\treturn getTypeReferenceShape(typeReference)\n\t}\n\n\t// Variable with `: Validator<...>` clause\n\tconst childTypeReferenceNode = innerLiteralNode.getParent()!.getFirstChildByKind(SyntaxKind.TypeReference)\n\tif (childTypeReferenceNode) {\n\t\treturn getTypeReferenceShape(childTypeReferenceNode)\n\t}\n\n\t// `RequiredParam<...>` inline call expression\n\tif (innerLiteralNode.getParent()!.getChildrenOfKind(SyntaxKind.SyntaxList).length >= 2) {\n\t\tconst typeNode = innerLiteralNode\n\t\t\t.getParent()!\n\t\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\t\t.getFirstChild()!\n\t\treturn getRecursiveNodeShape(typeNode)\n\t}\n\n\t// `RequestParam | RequiredParam | OptionalParam` call expression\n\tconst childCallExpressionNode = innerLiteralNode.getParent()!.getFirstChildByKind(SyntaxKind.CallExpression)\n\tif (childCallExpressionNode) {\n\t\tconst callExpressionArgument = findNodeImplementation(\n\t\t\tchildCallExpressionNode.getFirstChildByKind(SyntaxKind.SyntaxList)!.getFirstChild()!,\n\t\t)\n\n\t\t// Param is a type reference\n\t\tconst typeReferenceNode = callExpressionArgument\n\t\t\t.getParent()!\n\t\t\t.getFirstChildByKind(SyntaxKind.TypeReference)!\n\t\tif (typeReferenceNode) {\n\t\t\treturn getProperTypeShape(typeReferenceNode.getType(), typeReferenceNode, [])\n\t\t}\n\n\t\tconst thingyNode = callExpressionArgument\n\t\t\t.getParent()!\n\t\t\t.getFirstChildByKind(SyntaxKind.ObjectLiteralExpression)!\n\t\tif (thingyNode) {\n\t\t\treturn getValidatorPropertyShape(thingyNode)\n\t\t}\n\n\t\tif (callExpressionArgument.getKind() === SyntaxKind.CallExpression) {\n\t\t\treturn getValidatorPropertyShape(callExpressionArgument)\n\t\t}\n\n\t\tif (callExpressionArgument.getKind() === SyntaxKind.IntersectionType) {\n\t\t\treturn getValidatorPropertyShape(callExpressionArgument)\n\t\t}\n\n\t\tconst fileName = innerLiteralNode.getSourceFile().getFilePath().split('/').pop()\n\t\tLogger.warn(`[${fileName}] Unknown call expression argument: ${callExpressionArgument.getKindName()}`)\n\t\treturn 'unknown_3'\n\t}\n\n\t// Attempting to infer type from `parse` function\n\tconst innerNodePropertyAssignments = innerLiteralNode\n\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\t.getChildrenOfKind(SyntaxKind.PropertyAssignment)\n\tconst parsePropertyAssignment = innerNodePropertyAssignments.find((prop) => {\n\t\treturn prop.getFirstChildByKind(SyntaxKind.Identifier)?.getText() === 'parse'\n\t})\n\tif (parsePropertyAssignment) {\n\t\tconst returnType = findPropertyAssignmentValueNode(parsePropertyAssignment)\n\t\t\t.asKind(SyntaxKind.ArrowFunction)!\n\t\t\t.getReturnType()\n\t\treturn getProperTypeShape(returnType, parsePropertyAssignment)\n\t}\n\n\t// Import statement\n\tconst importTypeNode = innerLiteralNode\n\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)\n\t\t?.getFirstChildByKind(SyntaxKind.ImportType)\n\tif (importTypeNode) {\n\t\tconst indexOfGreaterThanToken = importTypeNode\n\t\t\t.getLastChildByKind(SyntaxKind.GreaterThanToken)!\n\t\t\t.getChildIndex()\n\t\tconst targetSyntaxList = importTypeNode.getChildAtIndex(indexOfGreaterThanToken - 1)\n\t\treturn getRecursiveNodeShape(targetSyntaxList.getFirstChild()!)\n\t}\n\n\t// Intersection type with Validator\n\tconst intersectionType = innerLiteralNode.isKind(SyntaxKind.IntersectionType)\n\t\t? innerLiteralNode\n\t\t: innerLiteralNode.getParent()?.isKind(SyntaxKind.VariableDeclaration)\n\t\t\t? innerLiteralNode.getParent()?.getFirstChildByKind(SyntaxKind.IntersectionType)\n\t\t\t: null\n\n\tif (intersectionType) {\n\t\tconst validatorType = intersectionType.getFirstChildByKind(SyntaxKind.TypeReference)\n\t\tif (validatorType) {\n\t\t\treturn getTypeReferenceShape(validatorType)\n\t\t}\n\t}\n\n\tconst fileName = innerLiteralNode.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown import type node`)\n\n\treturn 'unknown_2'\n}\n\nexport const getValidatorPropertyOptionality = (node: Node): boolean => {\n\tif (isZodCallExpression(node)) {\n\t\treturn false\n\t}\n\n\tconst callExpressionNode = node.asKind(SyntaxKind.CallExpression)\n\tif (callExpressionNode) {\n\t\tconst identifierNode = callExpressionNode.getFirstChildByKind(SyntaxKind.Identifier)\n\t\tif (identifierNode?.getText() === 'OptionalParam') {\n\t\t\treturn true\n\t\t} else if (identifierNode?.getText() === 'RequiredParam') {\n\t\t\treturn false\n\t\t}\n\n\t\tconst syntaxListNode = callExpressionNode.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\tconst literalExpression = findNodeImplementation(syntaxListNode.getFirstChild()!)\n\t\treturn getValidatorPropertyOptionality(literalExpression)\n\t}\n\n\tconst syntaxListNode = node.getFirstDescendantByKind(SyntaxKind.SyntaxList)!\n\tconst assignmentNodes = syntaxListNode.getChildrenOfKind(SyntaxKind.PropertyAssignment)!\n\n\treturn assignmentNodes.some((node) => {\n\t\tconst identifierNode = node.getFirstDescendantByKind(SyntaxKind.Identifier)!\n\t\tconst identifierName = identifierNode.getText()\n\n\t\tif (identifierName === 'optional') {\n\t\t\tconst value = findPropertyAssignmentValueNode(node)\n\t\t\treturn value.getKind() === SyntaxKind.TrueKeyword\n\t\t}\n\t\treturn false\n\t})\n}\n\nexport const getValidatorPropertyStringValue = (\n\tnodeOrReference: Node,\n\tname: 'description' | 'errorMessage',\n): string => {\n\tif (isZodCallExpression(nodeOrReference)) {\n\t\treturn ''\n\t}\n\n\tconst node = findNodeImplementation(nodeOrReference)\n\n\tconst callExpressionNode = node.asKind(SyntaxKind.CallExpression)\n\tif (callExpressionNode) {\n\t\tconst targetChild = callExpressionNode.getLastChildByKind(SyntaxKind.SyntaxList)!\n\t\treturn getValidatorPropertyStringValue(targetChild, name)\n\t}\n\n\tconst syntaxListNode = node.asKind(SyntaxKind.SyntaxList)\n\tif (syntaxListNode) {\n\t\tconst children = syntaxListNode.getChildren().map((c) => getValidatorPropertyStringValue(c, name))\n\t\treturn children.find((value) => !!value && value !== 'unknown_25') || ''\n\t}\n\n\tconst objectLiteralNode = node.asKind(SyntaxKind.ObjectLiteralExpression)\n\tif (objectLiteralNode) {\n\t\tconst values = getValuesOfObjectLiteral(objectLiteralNode)\n\t\tconst targetValue = values.find((value) => value.identifier === name)\n\t\tif (!targetValue) {\n\t\t\treturn ''\n\t\t}\n\t\tif (Array.isArray(targetValue.value)) {\n\t\t\treturn 'array'\n\t\t}\n\t\treturn targetValue.value || ''\n\t}\n\n\tconst intersectionTypeNode = node.asKind(SyntaxKind.IntersectionType)\n\tif (intersectionTypeNode) {\n\t\treturn (\n\t\t\tintersectionTypeNode\n\t\t\t\t.getTypeNodes()\n\t\t\t\t.flatMap((t) => getValidatorPropertyStringValue(t, name))\n\t\t\t\t.filter((v) => !!v && v !== 'unknown_25')[0] || 'unknown_27'\n\t\t)\n\t}\n\n\tconst typeLiteralNode = node.asKind(SyntaxKind.TypeLiteral)\n\tif (typeLiteralNode) {\n\t\treturn getValidatorPropertyStringValue(typeLiteralNode.getFirstChildByKind(SyntaxKind.SyntaxList)!, name)\n\t}\n\n\tconst propertySignatureNode = node.asKind(SyntaxKind.PropertySignature)\n\tif (propertySignatureNode) {\n\t\tconst identifier = node.getFirstDescendantByKind(SyntaxKind.Identifier)!\n\t\tif (identifier.getText() === name) {\n\t\t\tconst targetNode = findPropertyAssignmentValueNode(propertySignatureNode).getFirstDescendantByKind(\n\t\t\t\tSyntaxKind.StringLiteral,\n\t\t\t)!\n\t\t\treturn targetNode.getLiteralText()\n\t\t}\n\t}\n\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.dev(`[${fileName}] Unknown property string value node ${node.getKindName()}`)\n\treturn 'unknown_25'\n}\n\nconst isPromise = (type: Type) => {\n\tconst symbol = type.getSymbol()\n\tif (!type.isObject() || !symbol) {\n\t\treturn false\n\t}\n\tconst args = type.getTypeArguments()\n\treturn symbol.getName() === 'Promise' && args.length === 1\n}\n\nexport const getProperTypeShape = (\n\ttypeOrPromise: Type,\n\tatLocation: Node,\n\tstack: Type[] = [],\n): ShapeOfType['shape'] => {\n\tconst typeName = typeOrPromise.getAliasSymbol()?.getName()\n\tif (typeName && OpenApiManager.getInstance().hasExposedModel(typeName)) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'ref',\n\t\t\t\tshape: typeName,\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tconst type = isPromise(typeOrPromise) ? typeOrPromise.getTypeArguments()[0] : typeOrPromise\n\n\tif (stack.some((previousType) => previousType === type)) {\n\t\treturn 'circular'\n\t}\n\n\tconst nextStack = stack.concat(type)\n\n\tif (type.getText() === 'void') {\n\t\treturn 'void'\n\t}\n\n\tif (type.isAny()) {\n\t\treturn 'any'\n\t}\n\n\tif (type.isUnknown()) {\n\t\treturn 'unknown'\n\t}\n\n\tif (type.isNull()) {\n\t\treturn 'null'\n\t}\n\n\tif (type.isUndefined()) {\n\t\treturn 'undefined'\n\t}\n\n\tif (type.isBoolean() || type.isBooleanLiteral()) {\n\t\treturn 'boolean'\n\t}\n\n\tif (type.isStringLiteral()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'literal_string' as const,\n\t\t\t\tshape: String(type.getLiteralValue()!),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isNumberLiteral()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'literal_number' as const,\n\t\t\t\tshape: String(type.getLiteralValue()!),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isString() || type.isTemplateLiteral()) {\n\t\treturn 'string'\n\t}\n\n\tif (type.isNumber()) {\n\t\treturn 'number'\n\t}\n\n\tif (type.getText() === 'bigint') {\n\t\treturn 'bigint'\n\t}\n\n\tif (type.isTuple()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'tuple' as const,\n\t\t\t\tshape: type.getTupleElements().map((t) => ({\n\t\t\t\t\trole: 'tuple_entry' as const,\n\t\t\t\t\tshape: getProperTypeShape(t, atLocation, nextStack),\n\t\t\t\t\toptional: false,\n\t\t\t\t})),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isArray()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'array' as const,\n\t\t\t\tshape: getProperTypeShape(type.getArrayElementType()!, atLocation, nextStack),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\t// Handles `interface Foo extends Array<T>` (e.g. Prisma's JsonArray)\n\t// which fails type.isArray() but is still array-like\n\tif (type.isObject()) {\n\t\tconst arrayElementType = type.getNumberIndexType()\n\t\tconst baseTypes = type.getBaseTypes()\n\t\tconst arrayBase = baseTypes?.find((base) => base.isArray())\n\t\tif (arrayBase) {\n\t\t\treturn [\n\t\t\t\t{\n\t\t\t\t\trole: 'array' as const,\n\t\t\t\t\tshape: getProperTypeShape(\n\t\t\t\t\t\tarrayBase.getArrayElementType() ?? arrayElementType!,\n\t\t\t\t\t\tatLocation,\n\t\t\t\t\t\tnextStack,\n\t\t\t\t\t),\n\t\t\t\t\toptional: false,\n\t\t\t\t},\n\t\t\t]\n\t\t}\n\t}\n\n\tconst typeSymbolName = type.getSymbol()?.getName()\n\n\tconst bufferLikeTypes = new Set([\n\t\t'Buffer',\n\t\t'Uint8Array',\n\t\t'Int8Array',\n\t\t'Uint8ClampedArray',\n\t\t'Int16Array',\n\t\t'Uint16Array',\n\t\t'Int32Array',\n\t\t'Uint32Array',\n\t\t'Float32Array',\n\t\t'Float64Array',\n\t\t'BigInt64Array',\n\t\t'BigUint64Array',\n\t\t'ArrayBuffer',\n\t\t'SharedArrayBuffer',\n\t\t'ReadableStream',\n\t])\n\n\tif (type.isObject() && typeSymbolName && bufferLikeTypes.has(typeSymbolName)) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'buffer' as const,\n\t\t\t\tshape: 'buffer',\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isObject() && typeSymbolName === 'RegExp') {\n\t\treturn 'string'\n\t}\n\n\tif (type.isObject() && typeSymbolName === 'Map') {\n\t\tconst typeArgs = type.getTypeArguments()\n\t\tconst valueType = typeArgs[1]\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'record' as const,\n\t\t\t\tshape: valueType ? getProperTypeShape(valueType, atLocation, nextStack) : 'unknown',\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isObject() && typeSymbolName === 'Set') {\n\t\tconst typeArgs = type.getTypeArguments()\n\t\tconst elementType = typeArgs[0]\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'array' as const,\n\t\t\t\tshape: elementType ? getProperTypeShape(elementType, atLocation, nextStack) : 'unknown',\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isObject() && type.getProperties().length === 0) {\n\t\tconst targetType = type.getAliasTypeArguments()[1] ?? type.getStringIndexType()\n\t\tif (targetType) {\n\t\t\treturn [\n\t\t\t\t{\n\t\t\t\t\trole: 'record' as const,\n\t\t\t\t\tshape: getProperTypeShape(targetType, atLocation, nextStack),\n\t\t\t\t\toptional: false,\n\t\t\t\t},\n\t\t\t]\n\t\t}\n\t}\n\n\tif (type.isObject()) {\n\t\tif (typeSymbolName === 'Date' || type.getText() === 'Date') {\n\t\t\treturn 'Date'\n\t\t}\n\t\treturn type\n\t\t\t.getProperties()\n\t\t\t.map((prop) => {\n\t\t\t\tconst valueDeclaration = prop.getValueDeclaration() || prop.getDeclarations()[0]!\n\t\t\t\tif (!valueDeclaration) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\trole: 'property' as const,\n\t\t\t\t\t\tidentifier: prop.getName(),\n\t\t\t\t\t\tshape: getProperTypeShape(prop.getTypeAtLocation(atLocation), atLocation, nextStack),\n\t\t\t\t\t\toptional: false,\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tconst valueDeclarationNode =\n\t\t\t\t\tvalueDeclaration.asKind(SyntaxKind.PropertySignature) ||\n\t\t\t\t\tvalueDeclaration.asKind(SyntaxKind.PropertyAssignment) ||\n\t\t\t\t\tvalueDeclaration.asKind(SyntaxKind.ShorthandPropertyAssignment)\n\n\t\t\t\tif (!valueDeclarationNode) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\trole: 'property' as const,\n\t\t\t\t\t\tidentifier: prop.getName(),\n\t\t\t\t\t\tshape: getProperTypeShape(prop.getTypeAtLocation(atLocation), atLocation, nextStack),\n\t\t\t\t\t\toptional: false,\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst isOptional = prop.getTypeAtLocation(atLocation).isNullable()\n\n\t\t\t\tconst shape = getProperTypeShape(prop.getTypeAtLocation(atLocation), atLocation, nextStack)\n\t\t\t\treturn {\n\t\t\t\t\trole: 'property' as const,\n\t\t\t\t\tidentifier: prop.getName(),\n\t\t\t\t\tshape: shape,\n\t\t\t\t\toptional: isOptional,\n\t\t\t\t}\n\t\t\t})\n\t\t\t.filter((val) => val.shape !== 'undefined')\n\t}\n\n\tif (type.isUnion()) {\n\t\tconst unfilteredShapes: ShapeOfUnionEntry[] = type.getUnionTypes().map((type) => ({\n\t\t\trole: 'union_entry',\n\t\t\tshape: getProperTypeShape(type, atLocation, nextStack),\n\t\t\toptional: false,\n\t\t}))\n\n\t\tconst dedupedShapes = unfilteredShapes.filter(\n\t\t\t(type, index, arr) => !arr.find((dup, dupIndex) => dup.shape === type.shape && dupIndex > index),\n\t\t)\n\t\tconst isNullable = dedupedShapes.some((shape) => shape.shape === 'undefined')\n\t\tconst shapes = dedupedShapes.filter((shape) => shape.shape !== 'undefined')\n\t\tif (shapes.length === 1) {\n\t\t\treturn shapes[0].shape\n\t\t}\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'union',\n\t\t\t\tshape: shapes,\n\t\t\t\toptional: isNullable,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isIntersection()) {\n\t\tconst children = type.getIntersectionTypes()\n\t\tconst shapesOfChildren = children\n\t\t\t.map((child) => getProperTypeShape(child, atLocation, nextStack))\n\t\t\t.filter((shape) => typeof shape !== 'string') as ShapeOfProperty[][]\n\t\treturn shapesOfChildren.reduce<ShapeOfType[]>((total, current) => [...total, ...current], [])\n\t}\n\n\tconst fileName = atLocation.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown type shape node ${typeOrPromise.getText()}`)\n\treturn 'unknown_5'\n}\n\nconst getLiteralValueOfNode = (node: Node): string | string[] | unknown[] => {\n\tif (node.isKind(SyntaxKind.Identifier)) {\n\t\treturn getLiteralValueOfNode(findNodeImplementation(node))\n\t} else if (node.isKind(SyntaxKind.StringLiteral)) {\n\t\treturn node.getLiteralValue()\n\t} else if (node.isKind(SyntaxKind.ArrayLiteralExpression)) {\n\t\treturn node.forEachChildAsArray().map((child) => getLiteralValueOfNode(child)) as string[]\n\t} else if (node.isKind(SyntaxKind.PropertyAccessExpression)) {\n\t\treturn getLiteralValueOfNode(findPropertyAssignmentValueNode(node))\n\t} else if (node.isKind(SyntaxKind.ObjectLiteralExpression)) {\n\t\treturn getValuesOfObjectLiteral(node)\n\t}\n\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.dev(`[${fileName}] Unknown literal value node ${node.getKindName()}`)\n\n\treturn 'unknown_6'\n}\n\nexport const resolveEndpointPath = (node: Node): string | null => {\n\tconst callExpression = node.getFirstDescendantByKind(SyntaxKind.CallExpression)\n\tif (!callExpression) return null\n\n\tconst firstArg = callExpression.getArguments()[0]\n\tif (!firstArg) return null\n\n\tconst argType = firstArg.getType()\n\tif (argType.isStringLiteral()) {\n\t\treturn argType.getLiteralValue() as string\n\t}\n\n\treturn null\n}\n\nexport const getValuesOfObjectLiteral = (objectLiteralNode: Node<ts.ObjectLiteralExpression>) => {\n\tconst syntaxListNode = objectLiteralNode.getFirstDescendantByKind(SyntaxKind.SyntaxList)!\n\tconst assignmentNodes = syntaxListNode.getChildrenOfKind(SyntaxKind.PropertyAssignment)!\n\n\tconst properties = assignmentNodes.map((node) => {\n\t\tconst identifierNode = node.getFirstDescendantByKind(SyntaxKind.Identifier)!\n\t\tconst identifierName = identifierNode.getText()\n\n\t\tconst assignmentValueNode = node.getLastChild()!\n\t\tconst targetNode = findNodeImplementation(assignmentValueNode)\n\t\tconst value = getLiteralValueOfNode(targetNode)\n\n\t\treturn {\n\t\t\tidentifier: identifierName,\n\t\t\tvalue,\n\t\t}\n\t})\n\n\treturn properties || []\n}\n"],"names":["implementationCache","findNodeImplementation","node","cached","SyntaxKind","implementationNode","assignmentValueNode","result","definitionNode","findPropertyAssignmentValueNode","identifierChildren","child","getTypeReferenceShape","firstChild","getRecursiveNodeShape","nodeOrReference","typeName","OpenApiManager","literalNode","typeLiteralNode","propNode","identifier","valueNode","questionMarkToken","typeReferenceNode","lastChild","getProperTypeShape","unionTypeNode","typeQueryNode","qualifiedNameNode","callExpressionNode","awaitExpressionNode","asExpressionNode","fileName","Logger","getShapeOfValidatorLiteral","objectLiteralNode","identifierNode","identifierName","innerLiteralNode","getValidatorPropertyShape","getValidatorPropertyOptionality","getValidatorPropertyStringValue","isZodCallExpression","callExpression","getZodCallShape","objectLiteral","syntaxList","prop","argNode","inlineValidatorAsExpression","typeReference","childTypeReferenceNode","typeNode","childCallExpressionNode","callExpressionArgument","thingyNode","parsePropertyAssignment","returnType","importTypeNode","indexOfGreaterThanToken","targetSyntaxList","intersectionType","validatorType","syntaxListNode","literalExpression","name","targetChild","c","value","targetValue","getValuesOfObjectLiteral","intersectionTypeNode","t","v","propertySignatureNode","isPromise","type","symbol","args","typeOrPromise","atLocation","stack","previousType","nextStack","arrayElementType","arrayBase","base","typeSymbolName","bufferLikeTypes","valueType","elementType","targetType","valueDeclaration","isOptional","shape","val","dedupedShapes","index","arr","dup","dupIndex","isNullable","shapes","total","current","getLiteralValueOfNode","resolveEndpointPath","firstArg","argType","targetNode"],"mappings":"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"}
1
+ {"version":3,"file":"nodeParsers.mjs","sources":["../../../src/openapi/analyzerModule/nodeParsers.ts"],"sourcesContent":["import {\n\tNode,\n\tPropertyAccessExpression,\n\tPropertyAssignment,\n\tPropertySignature,\n\tShorthandPropertyAssignment,\n\tSyntaxKind,\n\tts,\n\tType,\n\tTypeReferenceNode,\n} from 'ts-morph'\n\nimport { Logger } from '../../utils/logger'\nimport { OpenApiManager } from '../manager/OpenApiManager'\nimport { ShapeOfProperty, ShapeOfType, ShapeOfUnionEntry } from './types'\n\nconst implementationCache = new WeakMap<Node, Node>()\n\nexport const findNodeImplementation = (node: Node): Node => {\n\tconst cached = implementationCache.get(node)\n\tif (cached) {\n\t\treturn cached\n\t}\n\n\tif (node.getKind() === SyntaxKind.Identifier) {\n\t\tconst implementationNode = node.asKind(SyntaxKind.Identifier)!.getImplementations()[0]?.getNode()\n\t\tif (implementationNode) {\n\t\t\tconst implementationParentNode = implementationNode.getParent()!\n\t\t\tconst assignmentValueNode = implementationParentNode.getLastChild()!\n\t\t\tif (assignmentValueNode === node) {\n\t\t\t\tthrow new Error('Recursive implementation found')\n\t\t\t}\n\t\t\tconst result = findNodeImplementation(assignmentValueNode)\n\t\t\timplementationCache.set(node, result)\n\t\t\treturn result\n\t\t}\n\n\t\tconst definitionNode = node.asKind(SyntaxKind.Identifier)!.getDefinitions()[0]?.getNode()\n\t\tif (definitionNode) {\n\t\t\tconst definitionParentNode = definitionNode.getParent()!\n\t\t\tconst assignmentValueNode = definitionParentNode.getLastChild()!\n\t\t\tif (assignmentValueNode === node) {\n\t\t\t\tthrow new Error('Recursive implementation found')\n\t\t\t}\n\t\t\tconst result = findNodeImplementation(assignmentValueNode)\n\t\t\timplementationCache.set(node, result)\n\t\t\treturn result\n\t\t}\n\t\tthrow new Error('No implementation nor definition available')\n\t}\n\n\timplementationCache.set(node, node)\n\treturn node\n}\n\nexport const findPropertyAssignmentValueNode = (\n\tnode:\n\t\t| PropertyAssignment\n\t\t| TypeReferenceNode\n\t\t| PropertySignature\n\t\t| PropertyAccessExpression\n\t\t| ShorthandPropertyAssignment,\n): Node => {\n\tconst identifierChildren = node.getChildrenOfKind(SyntaxKind.Identifier)\n\tif (identifierChildren.length === 2) {\n\t\treturn findNodeImplementation(identifierChildren[1])\n\t}\n\tconst lastMatchingChild = node.getChildren().reverse()\n\treturn lastMatchingChild.find(\n\t\t(child) =>\n\t\t\tchild.getKind() !== SyntaxKind.GreaterThanToken &&\n\t\t\tchild.getKind() !== SyntaxKind.CommaToken &&\n\t\t\tchild.getKind() !== SyntaxKind.SemicolonToken,\n\t)!\n}\n\nexport const getTypeReferenceShape = (node: TypeReferenceNode): ShapeOfType['shape'] => {\n\tconst firstChild = node.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\tif (firstChild.isKind(SyntaxKind.SyntaxList)) {\n\t\treturn getRecursiveNodeShape(firstChild.getFirstChild()!)\n\t} else {\n\t\treturn getRecursiveNodeShape(firstChild)\n\t}\n}\n\nexport const getRecursiveNodeShape = (nodeOrReference: Node): ShapeOfType['shape'] => {\n\tconst typeName = nodeOrReference.getSymbol()?.getName()\n\tif (typeName && OpenApiManager.getInstance().hasExposedModel(typeName)) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'ref',\n\t\t\t\tshape: typeName,\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tconst node = findNodeImplementation(nodeOrReference)\n\n\t// Undefined\n\tconst undefinedNode = node.asKind(SyntaxKind.UndefinedKeyword)\n\tif (undefinedNode) {\n\t\treturn 'undefined'\n\t}\n\n\t// Literal type\n\tconst literalNode = node.asKind(SyntaxKind.LiteralType)\n\tif (literalNode) {\n\t\tif (literalNode.getFirstChildByKind(SyntaxKind.TrueKeyword)) {\n\t\t\treturn 'true'\n\t\t}\n\t\tif (literalNode.getFirstChildByKind(SyntaxKind.FalseKeyword)) {\n\t\t\treturn 'false'\n\t\t}\n\t}\n\n\t// Boolean literal\n\tconst booleanLiteralNode =\n\t\tnode.asKind(SyntaxKind.BooleanKeyword) ||\n\t\tnode.asKind(SyntaxKind.TrueKeyword) ||\n\t\tnode.asKind(SyntaxKind.FalseKeyword)\n\tif (booleanLiteralNode) {\n\t\treturn 'boolean'\n\t}\n\n\t// String literal\n\tconst stringLiteralNode = node.asKind(SyntaxKind.StringKeyword) || node.asKind(SyntaxKind.StringLiteral)\n\tif (stringLiteralNode) {\n\t\treturn 'string'\n\t}\n\n\t// Number literal\n\tconst numberLiteralNode = node.asKind(SyntaxKind.NumberKeyword) || node.asKind(SyntaxKind.NumericLiteral)\n\tif (numberLiteralNode) {\n\t\treturn 'number'\n\t}\n\n\t// BigInt literal\n\tconst bigIntNode = node.asKind(SyntaxKind.BigIntKeyword) || node.asKind(SyntaxKind.BigIntLiteral)\n\tif (bigIntNode) {\n\t\treturn 'bigint'\n\t}\n\n\t// Type literal\n\tconst typeLiteralNode = node.asKind(SyntaxKind.TypeLiteral)\n\tif (typeLiteralNode) {\n\t\tconst properties = typeLiteralNode\n\t\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\t\t.getChildrenOfKind(SyntaxKind.PropertySignature)\n\n\t\tconst propertyShapes = properties.map((propNode) => {\n\t\t\tconst identifier = propNode.getFirstChildByKind(SyntaxKind.Identifier)!\n\t\t\tconst valueNode = findPropertyAssignmentValueNode(propNode)\n\t\t\tconst questionMarkToken = identifier.getNextSiblingIfKind(SyntaxKind.QuestionToken)\n\t\t\treturn {\n\t\t\t\trole: 'property' as const,\n\t\t\t\tidentifier: identifier.getText(),\n\t\t\t\tshape: getRecursiveNodeShape(valueNode),\n\t\t\t\toptional: valueNode.getType().isNullable() || !!questionMarkToken,\n\t\t\t}\n\t\t})\n\t\treturn propertyShapes\n\t}\n\n\t// Type reference\n\tconst typeReferenceNode = node.asKind(SyntaxKind.TypeReference)\n\tif (typeReferenceNode) {\n\t\treturn getRecursiveNodeShape(typeReferenceNode.getFirstChild()!)\n\t}\n\n\t// Property access expression\n\tconst propertyAccessNode = node.asKind(SyntaxKind.PropertyAccessExpression)\n\tif (propertyAccessNode) {\n\t\tconst lastChild = findNodeImplementation(node.getLastChild()!)\n\t\treturn getProperTypeShape(lastChild.asKind(SyntaxKind.CallExpression)!.getReturnType(), lastChild)\n\t}\n\n\t// Union type\n\tconst unionTypeNode = node.asKind(SyntaxKind.UnionType)\n\tif (unionTypeNode) {\n\t\treturn getProperTypeShape(unionTypeNode.getType(), node)\n\t}\n\n\t// Typeof query\n\tconst typeQueryNode = node.asKind(SyntaxKind.TypeQuery)\n\tif (typeQueryNode) {\n\t\treturn getRecursiveNodeShape(typeQueryNode.getLastChild()!)\n\t}\n\n\t// Qualified name\n\tconst qualifiedNameNode = node.asKind(SyntaxKind.QualifiedName)\n\tif (qualifiedNameNode) {\n\t\treturn getRecursiveNodeShape(qualifiedNameNode.getLastChild()!)\n\t}\n\n\t// Call expression\n\tconst callExpressionNode = node.asKind(SyntaxKind.CallExpression)\n\tif (callExpressionNode) {\n\t\treturn getProperTypeShape(callExpressionNode.getReturnType(), callExpressionNode)\n\t}\n\n\t// Await expression\n\tconst awaitExpressionNode = node.asKind(SyntaxKind.AwaitExpression)\n\tif (awaitExpressionNode) {\n\t\treturn getRecursiveNodeShape(awaitExpressionNode.getChildAtIndex(1)!)\n\t}\n\n\t// 'As' Expression\n\tconst asExpressionNode = node.asKind(SyntaxKind.AsExpression)\n\tif (asExpressionNode) {\n\t\treturn getRecursiveNodeShape(asExpressionNode.getChildAtIndex(2)!)\n\t}\n\n\t// TODO\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown node type: ${node.getKindName()}`)\n\treturn 'unknown_1'\n}\n\nexport const getShapeOfValidatorLiteral = (\n\tobjectLiteralNode: Node<ts.ObjectLiteralExpression>,\n): (ShapeOfProperty & { description: string; errorMessage: string })[] => {\n\tconst syntaxListNode = objectLiteralNode.getFirstDescendantByKind(SyntaxKind.SyntaxList)!\n\tconst assignmentNodes = syntaxListNode.getChildrenOfKind(SyntaxKind.PropertyAssignment)!\n\n\tconst properties = assignmentNodes.map((node) => {\n\t\tconst identifierNode = node.getFirstChild()!\n\t\tconst identifierName = (() => {\n\t\t\tif (identifierNode.isKind(SyntaxKind.Identifier)) {\n\t\t\t\treturn identifierNode.getText()\n\t\t\t}\n\t\t\tif (identifierNode.isKind(SyntaxKind.StringLiteral)) {\n\t\t\t\treturn identifierNode.getLiteralText()\n\t\t\t}\n\t\t\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\t\t\tLogger.warn(`[${fileName}] Unknown identifier name: ${identifierNode.getText()}`)\n\t\t\treturn 'unknown_30'\n\t\t})()\n\n\t\tconst assignmentValueNode = node.getLastChild()!\n\t\tconst innerLiteralNode = findNodeImplementation(assignmentValueNode)\n\n\t\treturn {\n\t\t\trole: 'property' as const,\n\t\t\tidentifier: identifierName,\n\t\t\tshape: getValidatorPropertyShape(innerLiteralNode),\n\t\t\toptional: getValidatorPropertyOptionality(innerLiteralNode),\n\t\t\tdescription: getValidatorPropertyStringValue(innerLiteralNode, 'description'),\n\t\t\terrorMessage: getValidatorPropertyStringValue(innerLiteralNode, 'errorMessage'),\n\t\t}\n\t})\n\n\treturn properties || []\n}\n\nconst isZodCallExpression = (node: Node): boolean => {\n\tconst callExpression = node.asKind(SyntaxKind.CallExpression)\n\tif (!callExpression) {\n\t\treturn false\n\t}\n\tconst returnType = callExpression.getReturnType()\n\tconst typeName = returnType.getSymbol()?.getName() ?? ''\n\treturn typeName.startsWith('Zod')\n}\n\nconst getZodCallShape = (node: Node): ShapeOfType['shape'] => {\n\tconst callExpression = node.asKind(SyntaxKind.CallExpression)!\n\tconst returnType = callExpression.getReturnType()\n\tconst typeName = returnType.getSymbol()?.getName() ?? ''\n\n\tif (typeName === 'ZodNumber') {\n\t\treturn 'number'\n\t}\n\tif (typeName === 'ZodString') {\n\t\treturn 'string'\n\t}\n\tif (typeName === 'ZodBoolean') {\n\t\treturn 'boolean'\n\t}\n\tif (typeName === 'ZodBigInt') {\n\t\treturn 'bigint'\n\t}\n\n\tif (typeName === 'ZodObject') {\n\t\tconst argNode = callExpression.getFirstChildByKind(SyntaxKind.SyntaxList)?.getFirstChild()\n\t\tconst objectLiteral = argNode?.asKind(SyntaxKind.ObjectLiteralExpression)\n\t\tif (!objectLiteral) {\n\t\t\treturn 'unknown_zod_object'\n\t\t}\n\t\tconst syntaxList = objectLiteral.getFirstChildByKind(SyntaxKind.SyntaxList)\n\t\tif (!syntaxList) {\n\t\t\treturn []\n\t\t}\n\t\tconst properties = syntaxList.getChildrenOfKind(SyntaxKind.PropertyAssignment)\n\t\treturn properties.map((prop) => {\n\t\t\tconst identifier = prop.getFirstChildByKind(SyntaxKind.Identifier)!.getText()\n\t\t\tconst valueNode = prop.getLastChild()!\n\t\t\treturn {\n\t\t\t\trole: 'property' as const,\n\t\t\t\tidentifier,\n\t\t\t\tshape: isZodCallExpression(valueNode)\n\t\t\t\t\t? getZodCallShape(valueNode)\n\t\t\t\t\t: getValidatorPropertyShape(valueNode),\n\t\t\t\toptional: false,\n\t\t\t}\n\t\t})\n\t}\n\n\tif (typeName === 'ZodArray') {\n\t\tconst argNode = callExpression.getFirstChildByKind(SyntaxKind.SyntaxList)?.getFirstChild()\n\t\tif (!argNode) {\n\t\t\treturn 'unknown_zod_array'\n\t\t}\n\t\tconst elementShape = isZodCallExpression(argNode)\n\t\t\t? getZodCallShape(argNode)\n\t\t\t: getValidatorPropertyShape(argNode)\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'array' as const,\n\t\t\t\tshape: elementShape,\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (typeName === 'ZodEnum') {\n\t\tconst typeArgs = returnType.getTypeArguments()\n\t\tif (typeArgs.length > 0) {\n\t\t\tconst enumType = typeArgs[0]\n\t\t\tconst properties = enumType.getProperties()\n\t\t\tconst shapes: ShapeOfUnionEntry[] = properties.map((prop) => ({\n\t\t\t\trole: 'union_entry' as const,\n\t\t\t\tshape: getProperTypeShape(prop.getTypeAtLocation(callExpression), callExpression, []),\n\t\t\t\toptional: false,\n\t\t\t}))\n\t\t\tif (shapes.length === 1) {\n\t\t\t\treturn shapes[0].shape\n\t\t\t}\n\t\t\tif (shapes.length > 1) {\n\t\t\t\treturn [\n\t\t\t\t\t{\n\t\t\t\t\t\trole: 'union' as const,\n\t\t\t\t\t\tshape: shapes,\n\t\t\t\t\t\toptional: false,\n\t\t\t\t\t},\n\t\t\t\t]\n\t\t\t}\n\t\t}\n\t\treturn 'unknown_zod_enum'\n\t}\n\n\tif (typeName === 'ZodOptional') {\n\t\tconst innerCallExpression = callExpression\n\t\t\t.getFirstChildByKind(SyntaxKind.PropertyAccessExpression)\n\t\t\t?.getFirstChildByKind(SyntaxKind.CallExpression)\n\t\tif (innerCallExpression && isZodCallExpression(innerCallExpression)) {\n\t\t\treturn getZodCallShape(innerCallExpression)\n\t\t}\n\t\treturn 'unknown_zod_optional'\n\t}\n\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown zod type: ${typeName}`)\n\treturn 'unknown_zod'\n}\n\nexport const getValidatorPropertyShape = (innerLiteralNode: Node): ShapeOfType['shape'] => {\n\t// Zod validator (e.g. z.number(), z.string(), z.object({...}), z.array(...))\n\tif (isZodCallExpression(innerLiteralNode)) {\n\t\treturn getZodCallShape(innerLiteralNode)\n\t}\n\n\t// Inline definition with `as Validator<...>` clause\n\tconst inlineValidatorAsExpression = innerLiteralNode\n\t\t.getParent()!\n\t\t.getFirstChildByKind(SyntaxKind.AsExpression)\n\tif (inlineValidatorAsExpression) {\n\t\tconst typeReference = inlineValidatorAsExpression.getLastChildByKind(SyntaxKind.TypeReference)!\n\t\treturn getTypeReferenceShape(typeReference)\n\t}\n\n\t// Variable with `: Validator<...>` clause\n\tconst childTypeReferenceNode = innerLiteralNode.getParent()!.getFirstChildByKind(SyntaxKind.TypeReference)\n\tif (childTypeReferenceNode) {\n\t\treturn getTypeReferenceShape(childTypeReferenceNode)\n\t}\n\n\t// `RequiredParam<...>` inline call expression\n\tif (innerLiteralNode.getParent()!.getChildrenOfKind(SyntaxKind.SyntaxList).length >= 2) {\n\t\tconst typeNode = innerLiteralNode\n\t\t\t.getParent()!\n\t\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\t\t.getFirstChild()!\n\t\treturn getRecursiveNodeShape(typeNode)\n\t}\n\n\t// `RequestParam | RequiredParam | OptionalParam` call expression\n\tconst childCallExpressionNode = innerLiteralNode.getParent()!.getFirstChildByKind(SyntaxKind.CallExpression)\n\tif (childCallExpressionNode) {\n\t\tconst callExpressionArgument = findNodeImplementation(\n\t\t\tchildCallExpressionNode.getFirstChildByKind(SyntaxKind.SyntaxList)!.getFirstChild()!,\n\t\t)\n\n\t\t// Param is a type reference\n\t\tconst typeReferenceNode = callExpressionArgument\n\t\t\t.getParent()!\n\t\t\t.getFirstChildByKind(SyntaxKind.TypeReference)!\n\t\tif (typeReferenceNode) {\n\t\t\treturn getProperTypeShape(typeReferenceNode.getType(), typeReferenceNode, [])\n\t\t}\n\n\t\tconst thingyNode = callExpressionArgument\n\t\t\t.getParent()!\n\t\t\t.getFirstChildByKind(SyntaxKind.ObjectLiteralExpression)!\n\t\tif (thingyNode) {\n\t\t\treturn getValidatorPropertyShape(thingyNode)\n\t\t}\n\n\t\tif (callExpressionArgument.getKind() === SyntaxKind.CallExpression) {\n\t\t\treturn getValidatorPropertyShape(callExpressionArgument)\n\t\t}\n\n\t\tif (callExpressionArgument.getKind() === SyntaxKind.IntersectionType) {\n\t\t\treturn getValidatorPropertyShape(callExpressionArgument)\n\t\t}\n\n\t\tconst fileName = innerLiteralNode.getSourceFile().getFilePath().split('/').pop()\n\t\tLogger.warn(`[${fileName}] Unknown call expression argument: ${callExpressionArgument.getKindName()}`)\n\t\treturn 'unknown_3'\n\t}\n\n\t// Attempting to infer type from `parse` function\n\tconst innerNodePropertyAssignments = innerLiteralNode\n\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\t.getChildrenOfKind(SyntaxKind.PropertyAssignment)\n\tconst parsePropertyAssignment = innerNodePropertyAssignments.find((prop) => {\n\t\treturn prop.getFirstChildByKind(SyntaxKind.Identifier)?.getText() === 'parse'\n\t})\n\tif (parsePropertyAssignment) {\n\t\tconst returnType = findPropertyAssignmentValueNode(parsePropertyAssignment)\n\t\t\t.asKind(SyntaxKind.ArrowFunction)!\n\t\t\t.getReturnType()\n\t\treturn getProperTypeShape(returnType, parsePropertyAssignment)\n\t}\n\n\t// Import statement\n\tconst importTypeNode = innerLiteralNode\n\t\t.getFirstChildByKind(SyntaxKind.SyntaxList)\n\t\t?.getFirstChildByKind(SyntaxKind.ImportType)\n\tif (importTypeNode) {\n\t\tconst indexOfGreaterThanToken = importTypeNode\n\t\t\t.getLastChildByKind(SyntaxKind.GreaterThanToken)!\n\t\t\t.getChildIndex()\n\t\tconst targetSyntaxList = importTypeNode.getChildAtIndex(indexOfGreaterThanToken - 1)\n\t\treturn getRecursiveNodeShape(targetSyntaxList.getFirstChild()!)\n\t}\n\n\t// Intersection type with Validator\n\tconst intersectionType = innerLiteralNode.isKind(SyntaxKind.IntersectionType)\n\t\t? innerLiteralNode\n\t\t: innerLiteralNode.getParent()?.isKind(SyntaxKind.VariableDeclaration)\n\t\t\t? innerLiteralNode.getParent()?.getFirstChildByKind(SyntaxKind.IntersectionType)\n\t\t\t: null\n\n\tif (intersectionType) {\n\t\tconst validatorType = intersectionType.getFirstChildByKind(SyntaxKind.TypeReference)\n\t\tif (validatorType) {\n\t\t\treturn getTypeReferenceShape(validatorType)\n\t\t}\n\t}\n\n\tconst fileName = innerLiteralNode.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown import type node`)\n\n\treturn 'unknown_2'\n}\n\nexport const getValidatorPropertyOptionality = (node: Node): boolean => {\n\tif (isZodCallExpression(node)) {\n\t\tconst callExpression = node.asKind(SyntaxKind.CallExpression)!\n\t\tconst returnType = callExpression.getReturnType()\n\t\tconst typeName = returnType.getSymbol()?.getName() ?? ''\n\t\tif (typeName === 'ZodOptional') {\n\t\t\treturn true\n\t\t}\n\t\treturn false\n\t}\n\n\tconst callExpressionNode = node.asKind(SyntaxKind.CallExpression)\n\tif (callExpressionNode) {\n\t\tconst identifierNode = callExpressionNode.getFirstChildByKind(SyntaxKind.Identifier)\n\t\tif (identifierNode?.getText() === 'OptionalParam') {\n\t\t\treturn true\n\t\t} else if (identifierNode?.getText() === 'RequiredParam') {\n\t\t\treturn false\n\t\t}\n\n\t\tconst syntaxListNode = callExpressionNode.getFirstChildByKind(SyntaxKind.SyntaxList)!\n\t\tconst literalExpression = findNodeImplementation(syntaxListNode.getFirstChild()!)\n\t\treturn getValidatorPropertyOptionality(literalExpression)\n\t}\n\n\tconst syntaxListNode = node.getFirstDescendantByKind(SyntaxKind.SyntaxList)!\n\tconst assignmentNodes = syntaxListNode.getChildrenOfKind(SyntaxKind.PropertyAssignment)!\n\n\treturn assignmentNodes.some((node) => {\n\t\tconst identifierNode = node.getFirstDescendantByKind(SyntaxKind.Identifier)!\n\t\tconst identifierName = identifierNode.getText()\n\n\t\tif (identifierName === 'optional') {\n\t\t\tconst value = findPropertyAssignmentValueNode(node)\n\t\t\treturn value.getKind() === SyntaxKind.TrueKeyword\n\t\t}\n\t\treturn false\n\t})\n}\n\nexport const getValidatorPropertyStringValue = (\n\tnodeOrReference: Node,\n\tname: 'description' | 'errorMessage',\n): string => {\n\tif (isZodCallExpression(nodeOrReference)) {\n\t\treturn ''\n\t}\n\n\tconst node = findNodeImplementation(nodeOrReference)\n\n\tconst callExpressionNode = node.asKind(SyntaxKind.CallExpression)\n\tif (callExpressionNode) {\n\t\tconst targetChild = callExpressionNode.getLastChildByKind(SyntaxKind.SyntaxList)!\n\t\treturn getValidatorPropertyStringValue(targetChild, name)\n\t}\n\n\tconst syntaxListNode = node.asKind(SyntaxKind.SyntaxList)\n\tif (syntaxListNode) {\n\t\tconst children = syntaxListNode.getChildren().map((c) => getValidatorPropertyStringValue(c, name))\n\t\treturn children.find((value) => !!value && value !== 'unknown_25') || ''\n\t}\n\n\tconst objectLiteralNode = node.asKind(SyntaxKind.ObjectLiteralExpression)\n\tif (objectLiteralNode) {\n\t\tconst values = getValuesOfObjectLiteral(objectLiteralNode)\n\t\tconst targetValue = values.find((value) => value.identifier === name)\n\t\tif (!targetValue) {\n\t\t\treturn ''\n\t\t}\n\t\tif (Array.isArray(targetValue.value)) {\n\t\t\treturn 'array'\n\t\t}\n\t\treturn targetValue.value || ''\n\t}\n\n\tconst intersectionTypeNode = node.asKind(SyntaxKind.IntersectionType)\n\tif (intersectionTypeNode) {\n\t\treturn (\n\t\t\tintersectionTypeNode\n\t\t\t\t.getTypeNodes()\n\t\t\t\t.flatMap((t) => getValidatorPropertyStringValue(t, name))\n\t\t\t\t.filter((v) => !!v && v !== 'unknown_25')[0] || 'unknown_27'\n\t\t)\n\t}\n\n\tconst typeLiteralNode = node.asKind(SyntaxKind.TypeLiteral)\n\tif (typeLiteralNode) {\n\t\treturn getValidatorPropertyStringValue(typeLiteralNode.getFirstChildByKind(SyntaxKind.SyntaxList)!, name)\n\t}\n\n\tconst propertySignatureNode = node.asKind(SyntaxKind.PropertySignature)\n\tif (propertySignatureNode) {\n\t\tconst identifier = node.getFirstDescendantByKind(SyntaxKind.Identifier)!\n\t\tif (identifier.getText() === name) {\n\t\t\tconst targetNode = findPropertyAssignmentValueNode(propertySignatureNode).getFirstDescendantByKind(\n\t\t\t\tSyntaxKind.StringLiteral,\n\t\t\t)!\n\t\t\treturn targetNode.getLiteralText()\n\t\t}\n\t}\n\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.dev(`[${fileName}] Unknown property string value node ${node.getKindName()}`)\n\treturn 'unknown_25'\n}\n\nconst isPromise = (type: Type) => {\n\tconst symbol = type.getSymbol()\n\tif (!type.isObject() || !symbol) {\n\t\treturn false\n\t}\n\tconst args = type.getTypeArguments()\n\treturn symbol.getName() === 'Promise' && args.length === 1\n}\n\nexport const getProperTypeShape = (\n\ttypeOrPromise: Type,\n\tatLocation: Node,\n\tstack: Type[] = [],\n): ShapeOfType['shape'] => {\n\tconst typeName = typeOrPromise.getAliasSymbol()?.getName()\n\tif (typeName && OpenApiManager.getInstance().hasExposedModel(typeName)) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'ref',\n\t\t\t\tshape: typeName,\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tconst type = isPromise(typeOrPromise) ? typeOrPromise.getTypeArguments()[0] : typeOrPromise\n\n\tif (stack.some((previousType) => previousType === type)) {\n\t\treturn 'circular'\n\t}\n\n\tconst nextStack = stack.concat(type)\n\n\tif (type.getText() === 'void') {\n\t\treturn 'void'\n\t}\n\n\tif (type.isAny()) {\n\t\treturn 'any'\n\t}\n\n\tif (type.isUnknown()) {\n\t\treturn 'unknown'\n\t}\n\n\tif (type.isNull()) {\n\t\treturn 'null'\n\t}\n\n\tif (type.isUndefined()) {\n\t\treturn 'undefined'\n\t}\n\n\tif (type.isBoolean() || type.isBooleanLiteral()) {\n\t\treturn 'boolean'\n\t}\n\n\tif (type.isStringLiteral()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'literal_string' as const,\n\t\t\t\tshape: String(type.getLiteralValue()!),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isNumberLiteral()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'literal_number' as const,\n\t\t\t\tshape: String(type.getLiteralValue()!),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isString() || type.isTemplateLiteral()) {\n\t\treturn 'string'\n\t}\n\n\tif (type.isNumber()) {\n\t\treturn 'number'\n\t}\n\n\tif (type.getText() === 'bigint') {\n\t\treturn 'bigint'\n\t}\n\n\tif (type.isTuple()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'tuple' as const,\n\t\t\t\tshape: type.getTupleElements().map((t) => ({\n\t\t\t\t\trole: 'tuple_entry' as const,\n\t\t\t\t\tshape: getProperTypeShape(t, atLocation, nextStack),\n\t\t\t\t\toptional: false,\n\t\t\t\t})),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isArray()) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'array' as const,\n\t\t\t\tshape: getProperTypeShape(type.getArrayElementType()!, atLocation, nextStack),\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\t// Handles `interface Foo extends Array<T>` (e.g. Prisma's JsonArray)\n\t// which fails type.isArray() but is still array-like\n\tif (type.isObject()) {\n\t\tconst arrayElementType = type.getNumberIndexType()\n\t\tconst baseTypes = type.getBaseTypes()\n\t\tconst arrayBase = baseTypes?.find((base) => base.isArray())\n\t\tif (arrayBase) {\n\t\t\treturn [\n\t\t\t\t{\n\t\t\t\t\trole: 'array' as const,\n\t\t\t\t\tshape: getProperTypeShape(\n\t\t\t\t\t\tarrayBase.getArrayElementType() ?? arrayElementType!,\n\t\t\t\t\t\tatLocation,\n\t\t\t\t\t\tnextStack,\n\t\t\t\t\t),\n\t\t\t\t\toptional: false,\n\t\t\t\t},\n\t\t\t]\n\t\t}\n\t}\n\n\tconst typeSymbolName = type.getSymbol()?.getName()\n\n\tconst bufferLikeTypes = new Set([\n\t\t'Buffer',\n\t\t'Uint8Array',\n\t\t'Int8Array',\n\t\t'Uint8ClampedArray',\n\t\t'Int16Array',\n\t\t'Uint16Array',\n\t\t'Int32Array',\n\t\t'Uint32Array',\n\t\t'Float32Array',\n\t\t'Float64Array',\n\t\t'BigInt64Array',\n\t\t'BigUint64Array',\n\t\t'ArrayBuffer',\n\t\t'SharedArrayBuffer',\n\t\t'ReadableStream',\n\t])\n\n\tif (type.isObject() && typeSymbolName && bufferLikeTypes.has(typeSymbolName)) {\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'buffer' as const,\n\t\t\t\tshape: 'buffer',\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isObject() && typeSymbolName === 'RegExp') {\n\t\treturn 'string'\n\t}\n\n\tif (type.isObject() && typeSymbolName === 'Map') {\n\t\tconst typeArgs = type.getTypeArguments()\n\t\tconst valueType = typeArgs[1]\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'record' as const,\n\t\t\t\tshape: valueType ? getProperTypeShape(valueType, atLocation, nextStack) : 'unknown',\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isObject() && typeSymbolName === 'Set') {\n\t\tconst typeArgs = type.getTypeArguments()\n\t\tconst elementType = typeArgs[0]\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'array' as const,\n\t\t\t\tshape: elementType ? getProperTypeShape(elementType, atLocation, nextStack) : 'unknown',\n\t\t\t\toptional: false,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isObject() && type.getProperties().length === 0) {\n\t\tconst targetType = type.getAliasTypeArguments()[1] ?? type.getStringIndexType()\n\t\tif (targetType) {\n\t\t\treturn [\n\t\t\t\t{\n\t\t\t\t\trole: 'record' as const,\n\t\t\t\t\tshape: getProperTypeShape(targetType, atLocation, nextStack),\n\t\t\t\t\toptional: false,\n\t\t\t\t},\n\t\t\t]\n\t\t}\n\t}\n\n\tif (type.isObject()) {\n\t\tif (typeSymbolName === 'Date' || type.getText() === 'Date') {\n\t\t\treturn 'Date'\n\t\t}\n\t\treturn type\n\t\t\t.getProperties()\n\t\t\t.map((prop) => {\n\t\t\t\tconst valueDeclaration = prop.getValueDeclaration() || prop.getDeclarations()[0]!\n\t\t\t\tif (!valueDeclaration) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\trole: 'property' as const,\n\t\t\t\t\t\tidentifier: prop.getName(),\n\t\t\t\t\t\tshape: getProperTypeShape(prop.getTypeAtLocation(atLocation), atLocation, nextStack),\n\t\t\t\t\t\toptional: false,\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tconst valueDeclarationNode =\n\t\t\t\t\tvalueDeclaration.asKind(SyntaxKind.PropertySignature) ||\n\t\t\t\t\tvalueDeclaration.asKind(SyntaxKind.PropertyAssignment) ||\n\t\t\t\t\tvalueDeclaration.asKind(SyntaxKind.ShorthandPropertyAssignment)\n\n\t\t\t\tif (!valueDeclarationNode) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\trole: 'property' as const,\n\t\t\t\t\t\tidentifier: prop.getName(),\n\t\t\t\t\t\tshape: getProperTypeShape(prop.getTypeAtLocation(atLocation), atLocation, nextStack),\n\t\t\t\t\t\toptional: false,\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst isOptional = prop.getTypeAtLocation(atLocation).isNullable()\n\n\t\t\t\tconst shape = getProperTypeShape(prop.getTypeAtLocation(atLocation), atLocation, nextStack)\n\t\t\t\treturn {\n\t\t\t\t\trole: 'property' as const,\n\t\t\t\t\tidentifier: prop.getName(),\n\t\t\t\t\tshape: shape,\n\t\t\t\t\toptional: isOptional,\n\t\t\t\t}\n\t\t\t})\n\t\t\t.filter((val) => val.shape !== 'undefined')\n\t}\n\n\tif (type.isUnion()) {\n\t\tconst unfilteredShapes: ShapeOfUnionEntry[] = type.getUnionTypes().map((type) => ({\n\t\t\trole: 'union_entry',\n\t\t\tshape: getProperTypeShape(type, atLocation, nextStack),\n\t\t\toptional: false,\n\t\t}))\n\n\t\tconst dedupedShapes = unfilteredShapes.filter(\n\t\t\t(type, index, arr) => !arr.find((dup, dupIndex) => dup.shape === type.shape && dupIndex > index),\n\t\t)\n\t\tconst isNullable = dedupedShapes.some((shape) => shape.shape === 'undefined')\n\t\tconst shapes = dedupedShapes.filter((shape) => shape.shape !== 'undefined')\n\t\tif (shapes.length === 1) {\n\t\t\treturn shapes[0].shape\n\t\t}\n\t\treturn [\n\t\t\t{\n\t\t\t\trole: 'union',\n\t\t\t\tshape: shapes,\n\t\t\t\toptional: isNullable,\n\t\t\t},\n\t\t]\n\t}\n\n\tif (type.isIntersection()) {\n\t\tconst children = type.getIntersectionTypes()\n\t\tconst shapesOfChildren = children\n\t\t\t.map((child) => getProperTypeShape(child, atLocation, nextStack))\n\t\t\t.filter((shape) => typeof shape !== 'string') as ShapeOfProperty[][]\n\t\treturn shapesOfChildren.reduce<ShapeOfType[]>((total, current) => [...total, ...current], [])\n\t}\n\n\tconst fileName = atLocation.getSourceFile().getFilePath().split('/').pop()\n\tLogger.warn(`[${fileName}] Unknown type shape node ${typeOrPromise.getText()}`)\n\treturn 'unknown_5'\n}\n\nconst getLiteralValueOfNode = (node: Node): string | string[] | unknown[] => {\n\tif (node.isKind(SyntaxKind.Identifier)) {\n\t\treturn getLiteralValueOfNode(findNodeImplementation(node))\n\t} else if (node.isKind(SyntaxKind.StringLiteral)) {\n\t\treturn node.getLiteralValue()\n\t} else if (node.isKind(SyntaxKind.ArrayLiteralExpression)) {\n\t\treturn node.forEachChildAsArray().map((child) => getLiteralValueOfNode(child)) as string[]\n\t} else if (node.isKind(SyntaxKind.PropertyAccessExpression)) {\n\t\treturn getLiteralValueOfNode(findPropertyAssignmentValueNode(node))\n\t} else if (node.isKind(SyntaxKind.ObjectLiteralExpression)) {\n\t\treturn getValuesOfObjectLiteral(node)\n\t}\n\n\tconst fileName = node.getSourceFile().getFilePath().split('/').pop()\n\tLogger.dev(`[${fileName}] Unknown literal value node ${node.getKindName()}`)\n\n\treturn 'unknown_6'\n}\n\nexport const resolveEndpointPath = (node: Node): string | null => {\n\tconst callExpression = node.getFirstDescendantByKind(SyntaxKind.CallExpression)\n\tif (!callExpression) return null\n\n\tconst firstArg = callExpression.getArguments()[0]\n\tif (!firstArg) return null\n\n\tconst argType = firstArg.getType()\n\tif (argType.isStringLiteral()) {\n\t\treturn argType.getLiteralValue() as string\n\t}\n\n\treturn null\n}\n\nexport const getValuesOfObjectLiteral = (objectLiteralNode: Node<ts.ObjectLiteralExpression>) => {\n\tconst syntaxListNode = objectLiteralNode.getFirstDescendantByKind(SyntaxKind.SyntaxList)!\n\tconst assignmentNodes = syntaxListNode.getChildrenOfKind(SyntaxKind.PropertyAssignment)!\n\n\tconst properties = assignmentNodes.map((node) => {\n\t\tconst identifierNode = node.getFirstDescendantByKind(SyntaxKind.Identifier)!\n\t\tconst identifierName = identifierNode.getText()\n\n\t\tconst assignmentValueNode = node.getLastChild()!\n\t\tconst targetNode = findNodeImplementation(assignmentValueNode)\n\t\tconst value = getLiteralValueOfNode(targetNode)\n\n\t\treturn {\n\t\t\tidentifier: identifierName,\n\t\t\tvalue,\n\t\t}\n\t})\n\n\treturn properties || []\n}\n"],"names":["implementationCache","findNodeImplementation","node","cached","SyntaxKind","implementationNode","assignmentValueNode","result","definitionNode","findPropertyAssignmentValueNode","identifierChildren","child","getTypeReferenceShape","firstChild","getRecursiveNodeShape","nodeOrReference","typeName","OpenApiManager","literalNode","typeLiteralNode","propNode","identifier","valueNode","questionMarkToken","typeReferenceNode","lastChild","getProperTypeShape","unionTypeNode","typeQueryNode","qualifiedNameNode","callExpressionNode","awaitExpressionNode","asExpressionNode","fileName","Logger","getShapeOfValidatorLiteral","objectLiteralNode","identifierNode","identifierName","innerLiteralNode","getValidatorPropertyShape","getValidatorPropertyOptionality","getValidatorPropertyStringValue","isZodCallExpression","callExpression","getZodCallShape","returnType","objectLiteral","syntaxList","prop","argNode","typeArgs","shapes","innerCallExpression","inlineValidatorAsExpression","typeReference","childTypeReferenceNode","typeNode","childCallExpressionNode","callExpressionArgument","thingyNode","parsePropertyAssignment","importTypeNode","indexOfGreaterThanToken","targetSyntaxList","intersectionType","validatorType","syntaxListNode","literalExpression","name","targetChild","c","value","targetValue","getValuesOfObjectLiteral","intersectionTypeNode","t","v","propertySignatureNode","isPromise","type","symbol","args","typeOrPromise","atLocation","stack","previousType","nextStack","arrayElementType","arrayBase","base","typeSymbolName","bufferLikeTypes","valueType","elementType","targetType","valueDeclaration","isOptional","shape","val","dedupedShapes","index","arr","dup","dupIndex","isNullable","total","current","getLiteralValueOfNode","resolveEndpointPath","firstArg","argType","targetNode"],"mappings":";;;AAgBA,MAAMA,wBAA0B,QAAoB,GAEvCC,IAAyB,CAACC,MAAqB;AACrD,QAAAC,IAASH,EAAoB,IAAIE,CAAI;AAC3C,MAAIC;AACI,WAAAA;AAGR,MAAID,EAAK,cAAcE,EAAW,YAAY;AACvC,UAAAC,IAAqBH,EAAK,OAAOE,EAAW,UAAU,EAAG,mBAAmB,EAAE,CAAC,GAAG,QAAQ;AAChG,QAAIC,GAAoB;AAEjB,YAAAC,IAD2BD,EAAmB,UAAU,EACT,aAAa;AAClE,UAAIC,MAAwBJ;AACrB,cAAA,IAAI,MAAM,gCAAgC;AAE3C,YAAAK,IAASN,EAAuBK,CAAmB;AACrC,aAAAN,EAAA,IAAIE,GAAMK,CAAM,GAC7BA;AAAA,IAAA;AAGF,UAAAC,IAAiBN,EAAK,OAAOE,EAAW,UAAU,EAAG,eAAe,EAAE,CAAC,GAAG,QAAQ;AACxF,QAAII,GAAgB;AAEb,YAAAF,IADuBE,EAAe,UAAU,EACL,aAAa;AAC9D,UAAIF,MAAwBJ;AACrB,cAAA,IAAI,MAAM,gCAAgC;AAE3C,YAAAK,IAASN,EAAuBK,CAAmB;AACrC,aAAAN,EAAA,IAAIE,GAAMK,CAAM,GAC7BA;AAAA,IAAA;AAEF,UAAA,IAAI,MAAM,4CAA4C;AAAA,EAAA;AAGzC,SAAAP,EAAA,IAAIE,GAAMA,CAAI,GAC3BA;AACR,GAEaO,IAAkC,CAC9CP,MAMU;AACV,QAAMQ,IAAqBR,EAAK,kBAAkBE,EAAW,UAAU;AACnE,SAAAM,EAAmB,WAAW,IAC1BT,EAAuBS,EAAmB,CAAC,CAAC,IAE1BR,EAAK,YAAY,EAAE,QAAQ,EAC5B;AAAA,IACxB,CAACS,MACAA,EAAM,QAAA,MAAcP,EAAW,oBAC/BO,EAAM,cAAcP,EAAW,cAC/BO,EAAM,QAAA,MAAcP,EAAW;AAAA,EACjC;AACD,GAEaQ,IAAwB,CAACV,MAAkD;AACvF,QAAMW,IAAaX,EAAK,oBAAoBE,EAAW,UAAU;AACjE,SAAIS,EAAW,OAAOT,EAAW,UAAU,IACnCU,EAAsBD,EAAW,eAAgB,IAEjDC,EAAsBD,CAAU;AAEzC,GAEaC,IAAwB,CAACC,MAAgD;AACrF,QAAMC,IAAWD,EAAgB,UAAU,GAAG,QAAQ;AACtD,MAAIC,KAAYC,EAAe,YAAc,EAAA,gBAAgBD,CAAQ;AAC7D,WAAA;AAAA,MACN;AAAA,QACC,MAAM;AAAA,QACN,OAAOA;AAAA,QACP,UAAU;AAAA,MAAA;AAAA,IAEZ;AAGK,QAAAd,IAAOD,EAAuBc,CAAe;AAInD,MADsBb,EAAK,OAAOE,EAAW,gBAAgB;AAErD,WAAA;AAIR,QAAMc,IAAchB,EAAK,OAAOE,EAAW,WAAW;AACtD,MAAIc,GAAa;AAChB,QAAIA,EAAY,oBAAoBd,EAAW,WAAW;AAClD,aAAA;AAER,QAAIc,EAAY,oBAAoBd,EAAW,YAAY;AACnD,aAAA;AAAA,EACR;AAQD,MAHCF,EAAK,OAAOE,EAAW,cAAc,KACrCF,EAAK,OAAOE,EAAW,WAAW,KAClCF,EAAK,OAAOE,EAAW,YAAY;AAE5B,WAAA;AAKR,MAD0BF,EAAK,OAAOE,EAAW,aAAa,KAAKF,EAAK,OAAOE,EAAW,aAAa;AAE/F,WAAA;AAKR,MAD0BF,EAAK,OAAOE,EAAW,aAAa,KAAKF,EAAK,OAAOE,EAAW,cAAc;AAEhG,WAAA;AAKR,MADmBF,EAAK,OAAOE,EAAW,aAAa,KAAKF,EAAK,OAAOE,EAAW,aAAa;AAExF,WAAA;AAIR,QAAMe,IAAkBjB,EAAK,OAAOE,EAAW,WAAW;AAC1D,MAAIe;AAgBI,WAfYA,EACjB,oBAAoBf,EAAW,UAAU,EACzC,kBAAkBA,EAAW,iBAAiB,EAEd,IAAI,CAACgB,MAAa;AACnD,YAAMC,IAAaD,EAAS,oBAAoBhB,EAAW,UAAU,GAC/DkB,IAAYb,EAAgCW,CAAQ,GACpDG,IAAoBF,EAAW,qBAAqBjB,EAAW,aAAa;AAC3E,aAAA;AAAA,QACN,MAAM;AAAA,QACN,YAAYiB,EAAW,QAAQ;AAAA,QAC/B,OAAOP,EAAsBQ,CAAS;AAAA,QACtC,UAAUA,EAAU,UAAU,WAAW,KAAK,CAAC,CAACC;AAAA,MACjD;AAAA,IAAA,CACA;AAKF,QAAMC,IAAoBtB,EAAK,OAAOE,EAAW,aAAa;AAC9D,MAAIoB;AACI,WAAAV,EAAsBU,EAAkB,eAAgB;AAKhE,MAD2BtB,EAAK,OAAOE,EAAW,wBAAwB,GAClD;AACvB,UAAMqB,IAAYxB,EAAuBC,EAAK,aAAA,CAAe;AACtD,WAAAwB,EAAmBD,EAAU,OAAOrB,EAAW,cAAc,EAAG,iBAAiBqB,CAAS;AAAA,EAAA;AAIlG,QAAME,IAAgBzB,EAAK,OAAOE,EAAW,SAAS;AACtD,MAAIuB;AACH,WAAOD,EAAmBC,EAAc,QAAQ,GAAGzB,CAAI;AAIxD,QAAM0B,IAAgB1B,EAAK,OAAOE,EAAW,SAAS;AACtD,MAAIwB;AACI,WAAAd,EAAsBc,EAAc,cAAe;AAI3D,QAAMC,IAAoB3B,EAAK,OAAOE,EAAW,aAAa;AAC9D,MAAIyB;AACI,WAAAf,EAAsBe,EAAkB,cAAe;AAI/D,QAAMC,IAAqB5B,EAAK,OAAOE,EAAW,cAAc;AAChE,MAAI0B;AACH,WAAOJ,EAAmBI,EAAmB,cAAc,GAAGA,CAAkB;AAIjF,QAAMC,IAAsB7B,EAAK,OAAOE,EAAW,eAAe;AAClE,MAAI2B;AACH,WAAOjB,EAAsBiB,EAAoB,gBAAgB,CAAC,CAAE;AAIrE,QAAMC,IAAmB9B,EAAK,OAAOE,EAAW,YAAY;AAC5D,MAAI4B;AACH,WAAOlB,EAAsBkB,EAAiB,gBAAgB,CAAC,CAAE;AAI5D,QAAAC,IAAW/B,EAAK,cAAc,EAAE,cAAc,MAAM,GAAG,EAAE,IAAI;AACnE,SAAAgC,EAAO,KAAK,IAAID,CAAQ,wBAAwB/B,EAAK,YAAa,CAAA,EAAE,GAC7D;AACR,GAEaiC,IAA6B,CACzCC,MAEuBA,EAAkB,yBAAyBhC,EAAW,UAAU,EAChD,kBAAkBA,EAAW,kBAAkB,EAEnD,IAAI,CAACF,MAAS;AAC1C,QAAAmC,IAAiBnC,EAAK,cAAc,GACpCoC,KAAkB,MAAM;AAC7B,QAAID,EAAe,OAAOjC,EAAW,UAAU;AAC9C,aAAOiC,EAAe,QAAQ;AAE/B,QAAIA,EAAe,OAAOjC,EAAW,aAAa;AACjD,aAAOiC,EAAe,eAAe;AAEhC,UAAAJ,IAAW/B,EAAK,cAAc,EAAE,cAAc,MAAM,GAAG,EAAE,IAAI;AACnE,WAAAgC,EAAO,KAAK,IAAID,CAAQ,8BAA8BI,EAAe,QAAS,CAAA,EAAE,GACzE;AAAA,EAAA,GACL,GAEG/B,IAAsBJ,EAAK,aAAa,GACxCqC,IAAmBtC,EAAuBK,CAAmB;AAE5D,SAAA;AAAA,IACN,MAAM;AAAA,IACN,YAAYgC;AAAA,IACZ,OAAOE,EAA0BD,CAAgB;AAAA,IACjD,UAAUE,EAAgCF,CAAgB;AAAA,IAC1D,aAAaG,EAAgCH,GAAkB,aAAa;AAAA,IAC5E,cAAcG,EAAgCH,GAAkB,cAAc;AAAA,EAC/E;AAAA,CACA,KAEoB,CAAC,GAGjBI,IAAsB,CAACzC,MAAwB;AACpD,QAAM0C,IAAiB1C,EAAK,OAAOE,EAAW,cAAc;AAC5D,SAAKwC,KAGcA,EAAe,cAAc,EACpB,UAAU,GAAG,QAAa,KAAA,IACtC,WAAW,KAAK,IAJxB;AAKT,GAEMC,IAAkB,CAAC3C,MAAqC;AAC7D,QAAM0C,IAAiB1C,EAAK,OAAOE,EAAW,cAAc,GACtD0C,IAAaF,EAAe,cAAc,GAC1C5B,IAAW8B,EAAW,UAAU,GAAG,QAAa,KAAA;AAEtD,MAAI9B,MAAa;AACT,WAAA;AAER,MAAIA,MAAa;AACT,WAAA;AAER,MAAIA,MAAa;AACT,WAAA;AAER,MAAIA,MAAa;AACT,WAAA;AAGR,MAAIA,MAAa,aAAa;AAE7B,UAAM+B,IADUH,EAAe,oBAAoBxC,EAAW,UAAU,GAAG,cAAc,GAC1D,OAAOA,EAAW,uBAAuB;AACxE,QAAI,CAAC2C;AACG,aAAA;AAER,UAAMC,IAAaD,EAAc,oBAAoB3C,EAAW,UAAU;AAC1E,WAAK4C,IAGcA,EAAW,kBAAkB5C,EAAW,kBAAkB,EAC3D,IAAI,CAAC6C,MAAS;AAC/B,YAAM5B,IAAa4B,EAAK,oBAAoB7C,EAAW,UAAU,EAAG,QAAQ,GACtEkB,IAAY2B,EAAK,aAAa;AAC7B,aAAA;AAAA,QACN,MAAM;AAAA,QACN,YAAA5B;AAAA,QACA,OAAOsB,EAAoBrB,CAAS,IACjCuB,EAAgBvB,CAAS,IACzBkB,EAA0BlB,CAAS;AAAA,QACtC,UAAU;AAAA,MACX;AAAA,IAAA,CACA,IAdO,CAAC;AAAA,EAcR;AAGF,MAAIN,MAAa,YAAY;AAC5B,UAAMkC,IAAUN,EAAe,oBAAoBxC,EAAW,UAAU,GAAG,cAAc;AACzF,WAAK8C,IAME;AAAA,MACN;AAAA,QACC,MAAM;AAAA,QACN,OANmBP,EAAoBO,CAAO,IAC7CL,EAAgBK,CAAO,IACvBV,EAA0BU,CAAO;AAAA,QAKlC,UAAU;AAAA,MAAA;AAAA,IAEZ,IAXQ;AAAA,EAWR;AAGD,MAAIlC,MAAa,WAAW;AACrB,UAAAmC,IAAWL,EAAW,iBAAiB;AACzC,QAAAK,EAAS,SAAS,GAAG;AAGxB,YAAMC,IAFWD,EAAS,CAAC,EACC,cAAc,EACK,IAAI,CAACF,OAAU;AAAA,QAC7D,MAAM;AAAA,QACN,OAAOvB,EAAmBuB,EAAK,kBAAkBL,CAAc,GAAGA,GAAgB,EAAE;AAAA,QACpF,UAAU;AAAA,MAAA,EACT;AACE,UAAAQ,EAAO,WAAW;AACd,eAAAA,EAAO,CAAC,EAAE;AAEd,UAAAA,EAAO,SAAS;AACZ,eAAA;AAAA,UACN;AAAA,YACC,MAAM;AAAA,YACN,OAAOA;AAAA,YACP,UAAU;AAAA,UAAA;AAAA,QAEZ;AAAA,IACD;AAEM,WAAA;AAAA,EAAA;AAGR,MAAIpC,MAAa,eAAe;AACzB,UAAAqC,IAAsBT,EAC1B,oBAAoBxC,EAAW,wBAAwB,GACtD,oBAAoBA,EAAW,cAAc;AAC5C,WAAAiD,KAAuBV,EAAoBU,CAAmB,IAC1DR,EAAgBQ,CAAmB,IAEpC;AAAA,EAAA;AAGF,QAAApB,IAAW/B,EAAK,cAAc,EAAE,cAAc,MAAM,GAAG,EAAE,IAAI;AACnE,SAAAgC,EAAO,KAAK,IAAID,CAAQ,uBAAuBjB,CAAQ,EAAE,GAClD;AACR,GAEawB,IAA4B,CAACD,MAAiD;AAEtF,MAAAI,EAAoBJ,CAAgB;AACvC,WAAOM,EAAgBN,CAAgB;AAIxC,QAAMe,IAA8Bf,EAClC,UACA,EAAA,oBAAoBnC,EAAW,YAAY;AAC7C,MAAIkD,GAA6B;AAChC,UAAMC,IAAgBD,EAA4B,mBAAmBlD,EAAW,aAAa;AAC7F,WAAOQ,EAAsB2C,CAAa;AAAA,EAAA;AAI3C,QAAMC,IAAyBjB,EAAiB,UAAa,EAAA,oBAAoBnC,EAAW,aAAa;AACzG,MAAIoD;AACH,WAAO5C,EAAsB4C,CAAsB;AAIhD,MAAAjB,EAAiB,YAAa,kBAAkBnC,EAAW,UAAU,EAAE,UAAU,GAAG;AACjF,UAAAqD,IAAWlB,EACf,UAAU,EACV,oBAAoBnC,EAAW,UAAU,EACzC,cAAc;AAChB,WAAOU,EAAsB2C,CAAQ;AAAA,EAAA;AAItC,QAAMC,IAA0BnB,EAAiB,UAAa,EAAA,oBAAoBnC,EAAW,cAAc;AAC3G,MAAIsD,GAAyB;AAC5B,UAAMC,IAAyB1D;AAAA,MAC9ByD,EAAwB,oBAAoBtD,EAAW,UAAU,EAAG,cAAc;AAAA,IACnF,GAGMoB,IAAoBmC,EACxB,UACA,EAAA,oBAAoBvD,EAAW,aAAa;AAC9C,QAAIoB;AACH,aAAOE,EAAmBF,EAAkB,QAAA,GAAWA,GAAmB,CAAA,CAAE;AAG7E,UAAMoC,IAAaD,EACjB,UACA,EAAA,oBAAoBvD,EAAW,uBAAuB;AACxD,QAAIwD;AACH,aAAOpB,EAA0BoB,CAAU;AAO5C,QAJID,EAAuB,cAAcvD,EAAW,kBAIhDuD,EAAuB,cAAcvD,EAAW;AACnD,aAAOoC,EAA0BmB,CAAsB;AAGlD1B,UAAAA,IAAWM,EAAiB,cAAc,EAAE,cAAc,MAAM,GAAG,EAAE,IAAI;AAC/E,WAAAL,EAAO,KAAK,IAAID,CAAQ,uCAAuC0B,EAAuB,YAAa,CAAA,EAAE,GAC9F;AAAA,EAAA;AAOR,QAAME,IAH+BtB,EACnC,oBAAoBnC,EAAW,UAAU,EACzC,kBAAkBA,EAAW,kBAAkB,EACY,KAAK,CAAC6C,MAC3DA,EAAK,oBAAoB7C,EAAW,UAAU,GAAG,cAAc,OACtE;AACD,MAAIyD,GAAyB;AACtB,UAAAf,IAAarC,EAAgCoD,CAAuB,EACxE,OAAOzD,EAAW,aAAa,EAC/B,cAAc;AACT,WAAAsB,EAAmBoB,GAAYe,CAAuB;AAAA,EAAA;AAIxD,QAAAC,IAAiBvB,EACrB,oBAAoBnC,EAAW,UAAU,GACxC,oBAAoBA,EAAW,UAAU;AAC5C,MAAI0D,GAAgB;AACnB,UAAMC,IAA0BD,EAC9B,mBAAmB1D,EAAW,gBAAgB,EAC9C,cAAc,GACV4D,IAAmBF,EAAe,gBAAgBC,IAA0B,CAAC;AAC5E,WAAAjD,EAAsBkD,EAAiB,eAAgB;AAAA,EAAA;AAIzD,QAAAC,IAAmB1B,EAAiB,OAAOnC,EAAW,gBAAgB,IACzEmC,IACAA,EAAiB,UAAU,GAAG,OAAOnC,EAAW,mBAAmB,IAClEmC,EAAiB,aAAa,oBAAoBnC,EAAW,gBAAgB,IAC7E;AAEJ,MAAI6D,GAAkB;AACrB,UAAMC,IAAgBD,EAAiB,oBAAoB7D,EAAW,aAAa;AACnF,QAAI8D;AACH,aAAOtD,EAAsBsD,CAAa;AAAA,EAC3C;AAGK,QAAAjC,IAAWM,EAAiB,cAAc,EAAE,cAAc,MAAM,GAAG,EAAE,IAAI;AACxE,SAAAL,EAAA,KAAK,IAAID,CAAQ,4BAA4B,GAE7C;AACR,GAEaQ,IAAkC,CAACvC,MAAwB;AACnE,MAAAyC,EAAoBzC,CAAI;AAI3B,YAHuBA,EAAK,OAAOE,EAAW,cAAc,EAC1B,cAAc,EACpB,UAAU,GAAG,QAAa,KAAA,QACrC;AAMlB,QAAM0B,IAAqB5B,EAAK,OAAOE,EAAW,cAAc;AAChE,MAAI0B,GAAoB;AACvB,UAAMO,IAAiBP,EAAmB,oBAAoB1B,EAAW,UAAU;AAC/E,QAAAiC,GAAgB,QAAQ,MAAM;AAC1B,aAAA;AACG,QAAAA,GAAgB,QAAQ,MAAM;AACjC,aAAA;AAGR,UAAM8B,IAAiBrC,EAAmB,oBAAoB1B,EAAW,UAAU,GAC7EgE,IAAoBnE,EAAuBkE,EAAe,cAAA,CAAgB;AAChF,WAAO1B,EAAgC2B,CAAiB;AAAA,EAAA;AAMlD,SAHgBlE,EAAK,yBAAyBE,EAAW,UAAU,EACnC,kBAAkBA,EAAW,kBAAkB,EAE/D,KAAK,CAACF,MACLA,EAAK,yBAAyBE,EAAW,UAAU,EACpC,QAAQ,MAEvB,aACRK,EAAgCP,CAAI,EACrC,cAAcE,EAAW,cAEhC,EACP;AACF,GAEasC,IAAkC,CAC9C3B,GACAsD,MACY;AACR,MAAA1B,EAAoB5B,CAAe;AAC/B,WAAA;AAGF,QAAAb,IAAOD,EAAuBc,CAAe,GAE7Ce,IAAqB5B,EAAK,OAAOE,EAAW,cAAc;AAChE,MAAI0B,GAAoB;AACvB,UAAMwC,IAAcxC,EAAmB,mBAAmB1B,EAAW,UAAU;AACxE,WAAAsC,EAAgC4B,GAAaD,CAAI;AAAA,EAAA;AAGzD,QAAMF,IAAiBjE,EAAK,OAAOE,EAAW,UAAU;AACxD,MAAI+D;AAEI,WADUA,EAAe,cAAc,IAAI,CAACI,MAAM7B,EAAgC6B,GAAGF,CAAI,CAAC,EACjF,KAAK,CAACG,MAAU,CAAC,CAACA,KAASA,MAAU,YAAY,KAAK;AAGvE,QAAMpC,IAAoBlC,EAAK,OAAOE,EAAW,uBAAuB;AACxE,MAAIgC,GAAmB;AAEtB,UAAMqC,IADSC,EAAyBtC,CAAiB,EAC9B,KAAK,CAACoC,MAAUA,EAAM,eAAeH,CAAI;AACpE,WAAKI,IAGD,MAAM,QAAQA,EAAY,KAAK,IAC3B,UAEDA,EAAY,SAAS,KALpB;AAAA,EAKoB;AAG7B,QAAME,IAAuBzE,EAAK,OAAOE,EAAW,gBAAgB;AACpE,MAAIuE;AAEF,WAAAA,EACE,eACA,QAAQ,CAACC,MAAMlC,EAAgCkC,GAAGP,CAAI,CAAC,EACvD,OAAO,CAACQ,MAAM,CAAC,CAACA,KAAKA,MAAM,YAAY,EAAE,CAAC,KAAK;AAInD,QAAM1D,IAAkBjB,EAAK,OAAOE,EAAW,WAAW;AAC1D,MAAIe;AACH,WAAOuB,EAAgCvB,EAAgB,oBAAoBf,EAAW,UAAU,GAAIiE,CAAI;AAGzG,QAAMS,IAAwB5E,EAAK,OAAOE,EAAW,iBAAiB;AACtE,MAAI0E,KACgB5E,EAAK,yBAAyBE,EAAW,UAAU,EACvD,QAAQ,MAAMiE;AAI5B,WAHmB5D,EAAgCqE,CAAqB,EAAE;AAAA,MACzE1E,EAAW;AAAA,IACZ,EACkB,eAAe;AAI7B,QAAA6B,IAAW/B,EAAK,cAAc,EAAE,cAAc,MAAM,GAAG,EAAE,IAAI;AACnE,SAAAgC,EAAO,IAAI,IAAID,CAAQ,wCAAwC/B,EAAK,YAAa,CAAA,EAAE,GAC5E;AACR,GAEM6E,IAAY,CAACC,MAAe;AAC3B,QAAAC,IAASD,EAAK,UAAU;AAC9B,MAAI,CAACA,EAAK,SAAS,KAAK,CAACC;AACjB,WAAA;AAEF,QAAAC,IAAOF,EAAK,iBAAiB;AACnC,SAAOC,EAAO,QAAc,MAAA,aAAaC,EAAK,WAAW;AAC1D,GAEaxD,IAAqB,CACjCyD,GACAC,GACAC,IAAgB,CAAA,MACU;AAC1B,QAAMrE,IAAWmE,EAAc,eAAe,GAAG,QAAQ;AACzD,MAAInE,KAAYC,EAAe,YAAc,EAAA,gBAAgBD,CAAQ;AAC7D,WAAA;AAAA,MACN;AAAA,QACC,MAAM;AAAA,QACN,OAAOA;AAAA,QACP,UAAU;AAAA,MAAA;AAAA,IAEZ;AAGK,QAAAgE,IAAOD,EAAUI,CAAa,IAAIA,EAAc,iBAAiB,EAAE,CAAC,IAAIA;AAE9E,MAAIE,EAAM,KAAK,CAACC,MAAiBA,MAAiBN,CAAI;AAC9C,WAAA;AAGF,QAAAO,IAAYF,EAAM,OAAOL,CAAI;AAE/B,MAAAA,EAAK,QAAQ,MAAM;AACf,WAAA;AAGJ,MAAAA,EAAK;AACD,WAAA;AAGJ,MAAAA,EAAK;AACD,WAAA;AAGJ,MAAAA,EAAK;AACD,WAAA;AAGJ,MAAAA,EAAK;AACD,WAAA;AAGR,MAAIA,EAAK,UAAA,KAAeA,EAAK;AACrB,WAAA;AAGJ,MAAAA,EAAK;AACD,WAAA;AAAA,MACN;AAAA,QACC,MAAM;AAAA,QACN,OAAO,OAAOA,EAAK,iBAAkB;AAAA,QACrC,UAAU;AAAA,MAAA;AAAA,IAEZ;AAGG,MAAAA,EAAK;AACD,WAAA;AAAA,MACN;AAAA,QACC,MAAM;AAAA,QACN,OAAO,OAAOA,EAAK,iBAAkB;AAAA,QACrC,UAAU;AAAA,MAAA;AAAA,IAEZ;AAGD,MAAIA,EAAK,SAAA,KAAcA,EAAK;AACpB,WAAA;AAGJ,MAAAA,EAAK;AACD,WAAA;AAGJ,MAAAA,EAAK,QAAQ,MAAM;AACf,WAAA;AAGJ,MAAAA,EAAK;AACD,WAAA;AAAA,MACN;AAAA,QACC,MAAM;AAAA,QACN,OAAOA,EAAK,iBAAmB,EAAA,IAAI,CAACJ,OAAO;AAAA,UAC1C,MAAM;AAAA,UACN,OAAOlD,EAAmBkD,GAAGQ,GAAYG,CAAS;AAAA,UAClD,UAAU;AAAA,QAAA,EACT;AAAA,QACF,UAAU;AAAA,MAAA;AAAA,IAEZ;AAGG,MAAAP,EAAK;AACD,WAAA;AAAA,MACN;AAAA,QACC,MAAM;AAAA,QACN,OAAOtD,EAAmBsD,EAAK,oBAAoB,GAAII,GAAYG,CAAS;AAAA,QAC5E,UAAU;AAAA,MAAA;AAAA,IAEZ;AAKG,MAAAP,EAAK,YAAY;AACd,UAAAQ,IAAmBR,EAAK,mBAAmB,GAE3CS,IADYT,EAAK,aAAa,GACP,KAAK,CAACU,MAASA,EAAK,SAAS;AAC1D,QAAID;AACI,aAAA;AAAA,QACN;AAAA,UACC,MAAM;AAAA,UACN,OAAO/D;AAAA,YACN+D,EAAU,yBAAyBD;AAAA,YACnCJ;AAAA,YACAG;AAAA,UACD;AAAA,UACA,UAAU;AAAA,QAAA;AAAA,MAEZ;AAAA,EACD;AAGD,QAAMI,IAAiBX,EAAK,UAAU,GAAG,QAAQ,GAE3CY,wBAAsB,IAAI;AAAA,IAC/B;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EAAA,CACA;AAED,MAAIZ,EAAK,cAAcW,KAAkBC,EAAgB,IAAID,CAAc;AACnE,WAAA;AAAA,MACN;AAAA,QACC,MAAM;AAAA,QACN,OAAO;AAAA,QACP,UAAU;AAAA,MAAA;AAAA,IAEZ;AAGD,MAAIX,EAAK,cAAcW,MAAmB;AAClC,WAAA;AAGR,MAAIX,EAAK,cAAcW,MAAmB,OAAO;AAE1C,UAAAE,IADWb,EAAK,iBAAiB,EACZ,CAAC;AACrB,WAAA;AAAA,MACN;AAAA,QACC,MAAM;AAAA,QACN,OAAOa,IAAYnE,EAAmBmE,GAAWT,GAAYG,CAAS,IAAI;AAAA,QAC1E,UAAU;AAAA,MAAA;AAAA,IAEZ;AAAA,EAAA;AAGD,MAAIP,EAAK,cAAcW,MAAmB,OAAO;AAE1C,UAAAG,IADWd,EAAK,iBAAiB,EACV,CAAC;AACvB,WAAA;AAAA,MACN;AAAA,QACC,MAAM;AAAA,QACN,OAAOc,IAAcpE,EAAmBoE,GAAaV,GAAYG,CAAS,IAAI;AAAA,QAC9E,UAAU;AAAA,MAAA;AAAA,IAEZ;AAAA,EAAA;AAGD,MAAIP,EAAK,cAAcA,EAAK,cAAc,EAAE,WAAW,GAAG;AACzD,UAAMe,IAAaf,EAAK,sBAAA,EAAwB,CAAC,KAAKA,EAAK,mBAAmB;AAC9E,QAAIe;AACI,aAAA;AAAA,QACN;AAAA,UACC,MAAM;AAAA,UACN,OAAOrE,EAAmBqE,GAAYX,GAAYG,CAAS;AAAA,UAC3D,UAAU;AAAA,QAAA;AAAA,MAEZ;AAAA,EACD;AAGG,MAAAP,EAAK;AACR,WAAIW,MAAmB,UAAUX,EAAK,QAAA,MAAc,SAC5C,SAEDA,EACL,cAAA,EACA,IAAI,CAAC/B,MAAS;AACd,YAAM+C,IAAmB/C,EAAK,oBAAA,KAAyBA,EAAK,kBAAkB,CAAC;AAC/E,UAAI,CAAC+C;AACG,eAAA;AAAA,UACN,MAAM;AAAA,UACN,YAAY/C,EAAK,QAAQ;AAAA,UACzB,OAAOvB,EAAmBuB,EAAK,kBAAkBmC,CAAU,GAAGA,GAAYG,CAAS;AAAA,UACnF,UAAU;AAAA,QACX;AAOD,UAAI,EAJHS,EAAiB,OAAO5F,EAAW,iBAAiB,KACpD4F,EAAiB,OAAO5F,EAAW,kBAAkB,KACrD4F,EAAiB,OAAO5F,EAAW,2BAA2B;AAGvD,eAAA;AAAA,UACN,MAAM;AAAA,UACN,YAAY6C,EAAK,QAAQ;AAAA,UACzB,OAAOvB,EAAmBuB,EAAK,kBAAkBmC,CAAU,GAAGA,GAAYG,CAAS;AAAA,UACnF,UAAU;AAAA,QACX;AAGD,YAAMU,IAAahD,EAAK,kBAAkBmC,CAAU,EAAE,WAAW,GAE3Dc,IAAQxE,EAAmBuB,EAAK,kBAAkBmC,CAAU,GAAGA,GAAYG,CAAS;AACnF,aAAA;AAAA,QACN,MAAM;AAAA,QACN,YAAYtC,EAAK,QAAQ;AAAA,QACzB,OAAAiD;AAAA,QACA,UAAUD;AAAA,MACX;AAAA,IAAA,CACA,EACA,OAAO,CAACE,MAAQA,EAAI,UAAU,WAAW;AAGxC,MAAAnB,EAAK,WAAW;AAOnB,UAAMoB,IANwCpB,EAAK,cAAgB,EAAA,IAAI,CAACA,OAAU;AAAA,MACjF,MAAM;AAAA,MACN,OAAOtD,EAAmBsD,GAAMI,GAAYG,CAAS;AAAA,MACrD,UAAU;AAAA,IAAA,EACT,EAEqC;AAAA,MACtC,CAACP,GAAMqB,GAAOC,MAAQ,CAACA,EAAI,KAAK,CAACC,GAAKC,MAAaD,EAAI,UAAUvB,EAAK,SAASwB,IAAWH,CAAK;AAAA,IAChG,GACMI,IAAaL,EAAc,KAAK,CAACF,MAAUA,EAAM,UAAU,WAAW,GACtE9C,IAASgD,EAAc,OAAO,CAACF,MAAUA,EAAM,UAAU,WAAW;AACtE,WAAA9C,EAAO,WAAW,IACdA,EAAO,CAAC,EAAE,QAEX;AAAA,MACN;AAAA,QACC,MAAM;AAAA,QACN,OAAOA;AAAA,QACP,UAAUqD;AAAA,MAAA;AAAA,IAEZ;AAAA,EAAA;AAGG,MAAAzB,EAAK;AAKR,WAJiBA,EAAK,qBAAqB,EAEzC,IAAI,CAACrE,MAAUe,EAAmBf,GAAOyE,GAAYG,CAAS,CAAC,EAC/D,OAAO,CAACW,MAAU,OAAOA,KAAU,QAAQ,EACrB,OAAsB,CAACQ,GAAOC,MAAY,CAAC,GAAGD,GAAO,GAAGC,CAAO,GAAG,EAAE;AAGvF,QAAA1E,IAAWmD,EAAW,cAAc,EAAE,cAAc,MAAM,GAAG,EAAE,IAAI;AACzE,SAAAlD,EAAO,KAAK,IAAID,CAAQ,6BAA6BkD,EAAc,QAAS,CAAA,EAAE,GACvE;AACR,GAEMyB,IAAwB,CAAC1G,MAA8C;AAC5E,MAAIA,EAAK,OAAOE,EAAW,UAAU;AAC7B,WAAAwG,EAAsB3G,EAAuBC,CAAI,CAAC;AAC/C,MAAAA,EAAK,OAAOE,EAAW,aAAa;AAC9C,WAAOF,EAAK,gBAAgB;AAClB,MAAAA,EAAK,OAAOE,EAAW,sBAAsB;AAChD,WAAAF,EAAK,sBAAsB,IAAI,CAACS,MAAUiG,EAAsBjG,CAAK,CAAC;AACnE,MAAAT,EAAK,OAAOE,EAAW,wBAAwB;AAClD,WAAAwG,EAAsBnG,EAAgCP,CAAI,CAAC;AACxD,MAAAA,EAAK,OAAOE,EAAW,uBAAuB;AACxD,WAAOsE,EAAyBxE,CAAI;AAG/B,QAAA+B,IAAW/B,EAAK,cAAc,EAAE,cAAc,MAAM,GAAG,EAAE,IAAI;AACnE,SAAAgC,EAAO,IAAI,IAAID,CAAQ,gCAAgC/B,EAAK,YAAa,CAAA,EAAE,GAEpE;AACR,GAEa2G,IAAsB,CAAC3G,MAA8B;AACjE,QAAM0C,IAAiB1C,EAAK,yBAAyBE,EAAW,cAAc;AAC1E,MAAA,CAACwC,EAAuB,QAAA;AAE5B,QAAMkE,IAAWlE,EAAe,aAAa,EAAE,CAAC;AAC5C,MAAA,CAACkE,EAAiB,QAAA;AAEhB,QAAAC,IAAUD,EAAS,QAAQ;AAC7B,SAAAC,EAAQ,oBACJA,EAAQ,gBAAgB,IAGzB;AACR,GAEarC,IAA2B,CAACtC,MACjBA,EAAkB,yBAAyBhC,EAAW,UAAU,EAChD,kBAAkBA,EAAW,kBAAkB,EAEnD,IAAI,CAACF,MAAS;AAE1C,QAAAoC,IADiBpC,EAAK,yBAAyBE,EAAW,UAAU,EACpC,QAAQ,GAExCE,IAAsBJ,EAAK,aAAa,GACxC8G,IAAa/G,EAAuBK,CAAmB,GACvDkE,IAAQoC,EAAsBI,CAAU;AAEvC,SAAA;AAAA,IACN,YAAY1E;AAAA,IACZ,OAAAkC;AAAA,EACD;AAAA,CACA,KAEoB,CAAC;"}
@@ -4,7 +4,9 @@ export declare const TestCase: {
4
4
  readonly parsesInlineZodObject: "parses-inline-zod-object";
5
5
  readonly parsesInlineZodNumberArray: "parses-inline-zod-number-array";
6
6
  readonly parsesInlineZodObjectArray: "parses-inline-zod-object-array";
7
- readonly parsedAliasedZodSchema: "parses-aliased-zod-schema";
7
+ readonly parsesInlineZodEnum: "parses-inline-zod-enum";
8
+ readonly parsesZodOptional: "parses-zod-optional";
9
+ readonly parsesAliasedZodSchema: "parses-aliased-zod-schema";
8
10
  readonly parsesReturnRecordStringUnknown: "parses-return-record-string-unknown";
9
11
  readonly parsesReturnObjectWithRecordProperty: "parses-return-object-with-record-property";
10
12
  readonly parsesBufferReturnedFromFunction: "parses-buffer-returned-from-function";
@@ -1 +1 @@
1
- {"version":3,"file":"TestCase.d.ts","sourceRoot":"","sources":["../../../../src/openapi/analyzerModule/test/TestCase.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,QAAQ;;;;;;;;;;;;;;;;;;;;CAoBX,CAAA"}
1
+ {"version":3,"file":"TestCase.d.ts","sourceRoot":"","sources":["../../../../src/openapi/analyzerModule/test/TestCase.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,QAAQ;;;;;;;;;;;;;;;;;;;;;;CAsBX,CAAA"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "moonflower",
3
- "version": "1.4.0",
3
+ "version": "1.4.2",
4
4
  "description": "",
5
5
  "author": "tenebrie",
6
6
  "license": "MIT",
@@ -1,3 +1,5 @@
1
+ import { describe, expect, it } from 'vitest'
2
+
1
3
  import { analyzeSourceFileExposedModels } from '../../openapi/analyzerModule/analyzerModule'
2
4
  import { loadTestData } from '../../utils/loadTestData'
3
5
  import { useExposeApiModel, useExposeNamedApiModels } from './useExposeApiModel'
@@ -323,6 +323,42 @@ const getZodCallShape = (node: Node): ShapeOfType['shape'] => {
323
323
  ]
324
324
  }
325
325
 
326
+ if (typeName === 'ZodEnum') {
327
+ const typeArgs = returnType.getTypeArguments()
328
+ if (typeArgs.length > 0) {
329
+ const enumType = typeArgs[0]
330
+ const properties = enumType.getProperties()
331
+ const shapes: ShapeOfUnionEntry[] = properties.map((prop) => ({
332
+ role: 'union_entry' as const,
333
+ shape: getProperTypeShape(prop.getTypeAtLocation(callExpression), callExpression, []),
334
+ optional: false,
335
+ }))
336
+ if (shapes.length === 1) {
337
+ return shapes[0].shape
338
+ }
339
+ if (shapes.length > 1) {
340
+ return [
341
+ {
342
+ role: 'union' as const,
343
+ shape: shapes,
344
+ optional: false,
345
+ },
346
+ ]
347
+ }
348
+ }
349
+ return 'unknown_zod_enum'
350
+ }
351
+
352
+ if (typeName === 'ZodOptional') {
353
+ const innerCallExpression = callExpression
354
+ .getFirstChildByKind(SyntaxKind.PropertyAccessExpression)
355
+ ?.getFirstChildByKind(SyntaxKind.CallExpression)
356
+ if (innerCallExpression && isZodCallExpression(innerCallExpression)) {
357
+ return getZodCallShape(innerCallExpression)
358
+ }
359
+ return 'unknown_zod_optional'
360
+ }
361
+
326
362
  const fileName = node.getSourceFile().getFilePath().split('/').pop()
327
363
  Logger.warn(`[${fileName}] Unknown zod type: ${typeName}`)
328
364
  return 'unknown_zod'
@@ -441,6 +477,12 @@ export const getValidatorPropertyShape = (innerLiteralNode: Node): ShapeOfType['
441
477
 
442
478
  export const getValidatorPropertyOptionality = (node: Node): boolean => {
443
479
  if (isZodCallExpression(node)) {
480
+ const callExpression = node.asKind(SyntaxKind.CallExpression)!
481
+ const returnType = callExpression.getReturnType()
482
+ const typeName = returnType.getSymbol()?.getName() ?? ''
483
+ if (typeName === 'ZodOptional') {
484
+ return true
485
+ }
444
486
  return false
445
487
  }
446
488
 
@@ -4,7 +4,9 @@ export const TestCase = {
4
4
  parsesInlineZodObject: 'parses-inline-zod-object',
5
5
  parsesInlineZodNumberArray: 'parses-inline-zod-number-array',
6
6
  parsesInlineZodObjectArray: 'parses-inline-zod-object-array',
7
- parsedAliasedZodSchema: 'parses-aliased-zod-schema',
7
+ parsesInlineZodEnum: 'parses-inline-zod-enum',
8
+ parsesZodOptional: 'parses-zod-optional',
9
+ parsesAliasedZodSchema: 'parses-aliased-zod-schema',
8
10
  parsesReturnRecordStringUnknown: 'parses-return-record-string-unknown',
9
11
  parsesReturnObjectWithRecordProperty: 'parses-return-object-with-record-property',
10
12
  parsesBufferReturnedFromFunction: 'parses-buffer-returned-from-function',
@@ -1,9 +1,11 @@
1
+ import { expectTypeOf } from 'vitest'
1
2
  import { z } from 'zod'
2
3
  import { z as valibot } from 'zod'
3
4
 
4
5
  import { usePathParams } from '../../../hooks/usePathParams'
5
6
  import { useRequestBody } from '../../../hooks/useRequestBody'
6
7
  import { Router } from '../../../router/Router'
8
+ import { OptionalParam } from '../../../validators/ParamWrappers'
7
9
  import { TestCase } from './TestCase'
8
10
 
9
11
  const router = new Router()
@@ -70,7 +72,7 @@ router.post(`/test/${TestCase.parsesInlineZodObjectArray}/:id`, (ctx) => {
70
72
  })
71
73
  })
72
74
 
73
- router.post(`/test/${TestCase.parsedAliasedZodSchema}/:id`, (ctx) => {
75
+ router.post(`/test/${TestCase.parsesAliasedZodSchema}/:id`, (ctx) => {
74
76
  const schema = valibot.array(
75
77
  valibot.object({
76
78
  value: valibot.number(),
@@ -85,3 +87,32 @@ router.post(`/test/${TestCase.parsedAliasedZodSchema}/:id`, (ctx) => {
85
87
  data: schema,
86
88
  })
87
89
  })
90
+
91
+ router.post(`/test/${TestCase.parsesInlineZodEnum}/:direction`, (ctx) => {
92
+ const MindmapLinkDirection = {
93
+ Normal: 'Normal',
94
+ Reversed: 'Reversed',
95
+ } as const
96
+
97
+ type MindmapLinkDirection = (typeof MindmapLinkDirection)[keyof typeof MindmapLinkDirection]
98
+
99
+ const path = usePathParams(ctx, {
100
+ direction: z.enum(MindmapLinkDirection),
101
+ })
102
+ const body = useRequestBody(ctx, {
103
+ direction: z.enum(MindmapLinkDirection),
104
+ optionalDirection: OptionalParam(z.enum(MindmapLinkDirection)),
105
+ })
106
+
107
+ expectTypeOf(path.direction).toEqualTypeOf<MindmapLinkDirection>()
108
+ expectTypeOf(body.direction).toEqualTypeOf<MindmapLinkDirection>()
109
+ expectTypeOf(body.optionalDirection).toEqualTypeOf<MindmapLinkDirection | undefined>()
110
+ })
111
+
112
+ router.post(`/test/${TestCase.parsesZodOptional}`, (ctx) => {
113
+ useRequestBody(ctx, {
114
+ requiredField: z.string(),
115
+ optionalField: z.string().optional(),
116
+ optionalNumber: z.number().optional(),
117
+ })
118
+ })
@@ -138,8 +138,70 @@ describe('OpenApi Analyzer (Zod Validator)', () => {
138
138
  expect(endpoint.objectBody[0].optional).toEqual(false)
139
139
  })
140
140
 
141
+ it('parses inline zod enum validators', () => {
142
+ const endpoint = analyzeEndpointById(TestCase.parsesInlineZodEnum)
143
+
144
+ const expectedSignature = [
145
+ {
146
+ role: 'union',
147
+ optional: false,
148
+ shape: [
149
+ {
150
+ role: 'union_entry',
151
+ shape: [
152
+ {
153
+ optional: false,
154
+ role: 'literal_string',
155
+ shape: 'Normal',
156
+ },
157
+ ],
158
+ optional: false,
159
+ },
160
+ {
161
+ role: 'union_entry',
162
+ shape: [
163
+ {
164
+ optional: false,
165
+ role: 'literal_string',
166
+ shape: 'Reversed',
167
+ },
168
+ ],
169
+ optional: false,
170
+ },
171
+ ],
172
+ },
173
+ ]
174
+
175
+ expect(endpoint.requestPathParams[0].identifier).toEqual('direction')
176
+ expect(endpoint.requestPathParams[0].signature).toEqual(expectedSignature)
177
+ expect(endpoint.requestPathParams[0].optional).toEqual(false)
178
+
179
+ expect(endpoint.objectBody[0].identifier).toEqual('direction')
180
+ expect(endpoint.objectBody[0].signature).toEqual(expectedSignature)
181
+ expect(endpoint.objectBody[0].optional).toEqual(false)
182
+ expect(endpoint.objectBody[1].identifier).toEqual('optionalDirection')
183
+ expect(endpoint.objectBody[1].signature).toEqual(expectedSignature)
184
+ expect(endpoint.objectBody[1].optional).toEqual(true)
185
+ })
186
+
187
+ it('parses zod optional validators', () => {
188
+ const endpoint = analyzeEndpointById(TestCase.parsesZodOptional)
189
+
190
+ expect(endpoint.objectBody[0].identifier).toEqual('requiredField')
191
+ expect(endpoint.objectBody[0].signature).toEqual('string')
192
+ expect(endpoint.objectBody[0].optional).toEqual(false)
193
+
194
+ expect(endpoint.objectBody[1].identifier).toEqual('optionalField')
195
+ expect(endpoint.objectBody[1].signature).toEqual('string')
196
+ expect(endpoint.objectBody[1].optional).toEqual(true)
197
+
198
+ expect(endpoint.objectBody[2].identifier).toEqual('optionalNumber')
199
+ expect(endpoint.objectBody[2].signature).toEqual('number')
200
+ expect(endpoint.objectBody[2].optional).toEqual(true)
201
+ })
202
+
141
203
  it('parses aliased zod object array validators', () => {
142
- const endpoint = analyzeEndpointById(TestCase.parsedAliasedZodSchema)
204
+ const endpoint = analyzeEndpointById(TestCase.parsesAliasedZodSchema)
143
205
 
144
206
  expect(endpoint.requestPathParams[0].identifier).toEqual('id')
145
207
  expect(endpoint.requestPathParams[0].signature).toEqual([