moonflower 0.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (268) hide show
  1. package/.eslintrc.js +26 -0
  2. package/.prettierrc.js +7 -0
  3. package/README.md +383 -0
  4. package/cli/cli.ts +59 -0
  5. package/cli/entry.cjs +3 -0
  6. package/cli/prettyprint.ts +16 -0
  7. package/dist/cli/cli.d.ts +2 -0
  8. package/dist/cli/cli.d.ts.map +1 -0
  9. package/dist/cli/cli.js +79 -0
  10. package/dist/cli/prettyprint.d.ts +4 -0
  11. package/dist/cli/prettyprint.d.ts.map +1 -0
  12. package/dist/cli/prettyprint.js +18 -0
  13. package/dist/src/errors/BaseHttpError.d.ts +13 -0
  14. package/dist/src/errors/BaseHttpError.d.ts.map +1 -0
  15. package/dist/src/errors/BaseHttpError.js +13 -0
  16. package/dist/src/errors/HttpErrorHandler.d.ts +3 -0
  17. package/dist/src/errors/HttpErrorHandler.d.ts.map +1 -0
  18. package/dist/src/errors/HttpErrorHandler.js +23 -0
  19. package/dist/src/errors/UserFacingErrors.d.ts +11 -0
  20. package/dist/src/errors/UserFacingErrors.d.ts.map +1 -0
  21. package/dist/src/errors/UserFacingErrors.js +23 -0
  22. package/dist/src/hooks/authentication/useAuth.d.ts +3 -0
  23. package/dist/src/hooks/authentication/useAuth.d.ts.map +1 -0
  24. package/dist/src/hooks/authentication/useAuth.js +7 -0
  25. package/dist/src/hooks/authentication/useOptionalAuth.d.ts +3 -0
  26. package/dist/src/hooks/authentication/useOptionalAuth.d.ts.map +1 -0
  27. package/dist/src/hooks/authentication/useOptionalAuth.js +16 -0
  28. package/dist/src/hooks/useApiEndpoint.d.ts +8 -0
  29. package/dist/src/hooks/useApiEndpoint.d.ts.map +1 -0
  30. package/dist/src/hooks/useApiEndpoint.js +7 -0
  31. package/dist/src/hooks/useApiHeader/index.d.ts +2 -0
  32. package/dist/src/hooks/useApiHeader/index.d.ts.map +1 -0
  33. package/dist/src/hooks/useApiHeader/index.js +17 -0
  34. package/dist/src/hooks/useApiHeader/useApiHeader.d.ts +3 -0
  35. package/dist/src/hooks/useApiHeader/useApiHeader.d.ts.map +1 -0
  36. package/dist/src/hooks/useApiHeader/useApiHeader.js +6 -0
  37. package/dist/src/hooks/useApiHeader/useApiHeader.spec.data.d.ts +2 -0
  38. package/dist/src/hooks/useApiHeader/useApiHeader.spec.data.d.ts.map +1 -0
  39. package/dist/src/hooks/useApiHeader/useApiHeader.spec.data.js +22 -0
  40. package/dist/src/hooks/useCookieParams.d.ts +9 -0
  41. package/dist/src/hooks/useCookieParams.d.ts.map +1 -0
  42. package/dist/src/hooks/useCookieParams.js +50 -0
  43. package/dist/src/hooks/useExposeApiModel/index.d.ts +2 -0
  44. package/dist/src/hooks/useExposeApiModel/index.d.ts.map +1 -0
  45. package/dist/src/hooks/useExposeApiModel/index.js +17 -0
  46. package/dist/src/hooks/useExposeApiModel/useExposeApiModel.d.ts +3 -0
  47. package/dist/src/hooks/useExposeApiModel/useExposeApiModel.d.ts.map +1 -0
  48. package/dist/src/hooks/useExposeApiModel/useExposeApiModel.js +9 -0
  49. package/dist/src/hooks/useExposeApiModel/useExposeApiModel.spec.data.d.ts +2 -0
  50. package/dist/src/hooks/useExposeApiModel/useExposeApiModel.spec.data.d.ts.map +1 -0
  51. package/dist/src/hooks/useExposeApiModel/useExposeApiModel.spec.data.js +16 -0
  52. package/dist/src/hooks/useHeaderParams.d.ts +12 -0
  53. package/dist/src/hooks/useHeaderParams.d.ts.map +1 -0
  54. package/dist/src/hooks/useHeaderParams.js +52 -0
  55. package/dist/src/hooks/usePathParams.d.ts +22 -0
  56. package/dist/src/hooks/usePathParams.d.ts.map +1 -0
  57. package/dist/src/hooks/usePathParams.js +46 -0
  58. package/dist/src/hooks/useQueryParams.d.ts +9 -0
  59. package/dist/src/hooks/useQueryParams.d.ts.map +1 -0
  60. package/dist/src/hooks/useQueryParams.js +50 -0
  61. package/dist/src/hooks/useRequestBody.d.ts +9 -0
  62. package/dist/src/hooks/useRequestBody.d.ts.map +1 -0
  63. package/dist/src/hooks/useRequestBody.js +59 -0
  64. package/dist/src/hooks/useRequestRawBody.d.ts +7 -0
  65. package/dist/src/hooks/useRequestRawBody.d.ts.map +1 -0
  66. package/dist/src/hooks/useRequestRawBody.js +34 -0
  67. package/dist/src/index.d.ts +18 -0
  68. package/dist/src/index.d.ts.map +1 -0
  69. package/dist/src/index.js +33 -0
  70. package/dist/src/openapi/analyzerModule/analyzerModule.d.ts +18 -0
  71. package/dist/src/openapi/analyzerModule/analyzerModule.d.ts.map +1 -0
  72. package/dist/src/openapi/analyzerModule/analyzerModule.js +192 -0
  73. package/dist/src/openapi/analyzerModule/nodeParsers.d.ts +19 -0
  74. package/dist/src/openapi/analyzerModule/nodeParsers.d.ts.map +1 -0
  75. package/dist/src/openapi/analyzerModule/nodeParsers.js +521 -0
  76. package/dist/src/openapi/analyzerModule/parseEndpoint.d.ts +4 -0
  77. package/dist/src/openapi/analyzerModule/parseEndpoint.d.ts.map +1 -0
  78. package/dist/src/openapi/analyzerModule/parseEndpoint.js +246 -0
  79. package/dist/src/openapi/analyzerModule/parseExposedModels.d.ts +5 -0
  80. package/dist/src/openapi/analyzerModule/parseExposedModels.d.ts.map +1 -0
  81. package/dist/src/openapi/analyzerModule/parseExposedModels.js +32 -0
  82. package/dist/src/openapi/analyzerModule/test/openApiAnalyzer.spec.data.d.ts +2 -0
  83. package/dist/src/openapi/analyzerModule/test/openApiAnalyzer.spec.data.d.ts.map +1 -0
  84. package/dist/src/openapi/analyzerModule/test/openApiAnalyzer.spec.data.js +400 -0
  85. package/dist/src/openapi/analyzerModule/types.d.ts +53 -0
  86. package/dist/src/openapi/analyzerModule/types.d.ts.map +1 -0
  87. package/dist/src/openapi/analyzerModule/types.js +2 -0
  88. package/dist/src/openapi/discoveryModule/discoverImports/discoverImports.d.ts +8 -0
  89. package/dist/src/openapi/discoveryModule/discoverImports/discoverImports.d.ts.map +1 -0
  90. package/dist/src/openapi/discoveryModule/discoverImports/discoverImports.js +33 -0
  91. package/dist/src/openapi/discoveryModule/discoverRouterFiles/data/testRouterA.spec.data.d.ts +4 -0
  92. package/dist/src/openapi/discoveryModule/discoverRouterFiles/data/testRouterA.spec.data.d.ts.map +1 -0
  93. package/dist/src/openapi/discoveryModule/discoverRouterFiles/data/testRouterA.spec.data.js +8 -0
  94. package/dist/src/openapi/discoveryModule/discoverRouterFiles/data/testRouterB.spec.data.d.ts +4 -0
  95. package/dist/src/openapi/discoveryModule/discoverRouterFiles/data/testRouterB.spec.data.d.ts.map +1 -0
  96. package/dist/src/openapi/discoveryModule/discoverRouterFiles/data/testRouterB.spec.data.js +8 -0
  97. package/dist/src/openapi/discoveryModule/discoverRouterFiles/discoverRouterFiles.d.ts +17 -0
  98. package/dist/src/openapi/discoveryModule/discoverRouterFiles/discoverRouterFiles.d.ts.map +1 -0
  99. package/dist/src/openapi/discoveryModule/discoverRouterFiles/discoverRouterFiles.js +80 -0
  100. package/dist/src/openapi/discoveryModule/discoverRouters/discoverRouters.d.ts +6 -0
  101. package/dist/src/openapi/discoveryModule/discoverRouters/discoverRouters.d.ts.map +1 -0
  102. package/dist/src/openapi/discoveryModule/discoverRouters/discoverRouters.js +31 -0
  103. package/dist/src/openapi/discoveryModule/discoverRouters/discoverRouters.spec.data.d.ts +5 -0
  104. package/dist/src/openapi/discoveryModule/discoverRouters/discoverRouters.spec.data.d.ts.map +1 -0
  105. package/dist/src/openapi/discoveryModule/discoverRouters/discoverRouters.spec.data.js +38 -0
  106. package/dist/src/openapi/discoveryModule/index.d.ts +3 -0
  107. package/dist/src/openapi/discoveryModule/index.d.ts.map +1 -0
  108. package/dist/src/openapi/discoveryModule/index.js +18 -0
  109. package/dist/src/openapi/generatorModule/generateComponentSchemas.d.ts +4 -0
  110. package/dist/src/openapi/generatorModule/generateComponentSchemas.d.ts.map +1 -0
  111. package/dist/src/openapi/generatorModule/generateComponentSchemas.js +12 -0
  112. package/dist/src/openapi/generatorModule/generatePaths.d.ts +10 -0
  113. package/dist/src/openapi/generatorModule/generatePaths.d.ts.map +1 -0
  114. package/dist/src/openapi/generatorModule/generatePaths.js +116 -0
  115. package/dist/src/openapi/generatorModule/generatorModule.d.ts +16 -0
  116. package/dist/src/openapi/generatorModule/generatorModule.d.ts.map +1 -0
  117. package/dist/src/openapi/generatorModule/generatorModule.js +18 -0
  118. package/dist/src/openapi/generatorModule/getSchema.d.ts +36 -0
  119. package/dist/src/openapi/generatorModule/getSchema.d.ts.map +1 -0
  120. package/dist/src/openapi/generatorModule/getSchema.js +133 -0
  121. package/dist/src/openapi/generatorModule/index.d.ts +5 -0
  122. package/dist/src/openapi/generatorModule/index.d.ts.map +1 -0
  123. package/dist/src/openapi/generatorModule/index.js +20 -0
  124. package/dist/src/openapi/generatorModule/test/openApiGenerator.spec.data.d.ts +515 -0
  125. package/dist/src/openapi/generatorModule/test/openApiGenerator.spec.data.d.ts.map +1 -0
  126. package/dist/src/openapi/generatorModule/test/openApiGenerator.spec.data.js +1119 -0
  127. package/dist/src/openapi/initOpenApiEngine.d.ts +4 -0
  128. package/dist/src/openapi/initOpenApiEngine.d.ts.map +1 -0
  129. package/dist/src/openapi/initOpenApiEngine.js +14 -0
  130. package/dist/src/openapi/manager/OpenApiManager.d.ts +67 -0
  131. package/dist/src/openapi/manager/OpenApiManager.d.ts.map +1 -0
  132. package/dist/src/openapi/manager/OpenApiManager.js +86 -0
  133. package/dist/src/openapi/router/OpenApiRouter.d.ts +4 -0
  134. package/dist/src/openapi/router/OpenApiRouter.d.ts.map +1 -0
  135. package/dist/src/openapi/router/OpenApiRouter.js +11 -0
  136. package/dist/src/openapi/types.d.ts +81 -0
  137. package/dist/src/openapi/types.d.ts.map +1 -0
  138. package/dist/src/openapi/types.js +2 -0
  139. package/dist/src/router/Router.d.ts +23 -0
  140. package/dist/src/router/Router.d.ts.map +1 -0
  141. package/dist/src/router/Router.js +81 -0
  142. package/dist/src/router/responseValueToJson.d.ts +2 -0
  143. package/dist/src/router/responseValueToJson.d.ts.map +1 -0
  144. package/dist/src/router/responseValueToJson.js +10 -0
  145. package/dist/src/setupTests.d.ts +1 -0
  146. package/dist/src/setupTests.d.ts.map +1 -0
  147. package/dist/src/setupTests.js +3 -0
  148. package/dist/src/test/TestAppRouter.d.ts +8 -0
  149. package/dist/src/test/TestAppRouter.d.ts.map +1 -0
  150. package/dist/src/test/TestAppRouter.js +58 -0
  151. package/dist/src/test/app.d.ts +3 -0
  152. package/dist/src/test/app.d.ts.map +1 -0
  153. package/dist/src/test/app.js +41 -0
  154. package/dist/src/utils/TypeUtils.d.ts +22 -0
  155. package/dist/src/utils/TypeUtils.d.ts.map +1 -0
  156. package/dist/src/utils/TypeUtils.js +2 -0
  157. package/dist/src/utils/fromZodSchema.d.ts +2 -0
  158. package/dist/src/utils/fromZodSchema.d.ts.map +1 -0
  159. package/dist/src/utils/fromZodSchema.js +6 -0
  160. package/dist/src/utils/loadTestData.d.ts +2 -0
  161. package/dist/src/utils/loadTestData.d.ts.map +1 -0
  162. package/dist/src/utils/loadTestData.js +39 -0
  163. package/dist/src/utils/mockContext.d.ts +20 -0
  164. package/dist/src/utils/mockContext.d.ts.map +1 -0
  165. package/dist/src/utils/mockContext.js +85 -0
  166. package/dist/src/utils/nameOf.d.ts +5 -0
  167. package/dist/src/utils/nameOf.d.ts.map +1 -0
  168. package/dist/src/utils/nameOf.js +7 -0
  169. package/dist/src/utils/object.d.ts +7 -0
  170. package/dist/src/utils/object.d.ts.map +1 -0
  171. package/dist/src/utils/object.js +21 -0
  172. package/dist/src/utils/printers.d.ts +6 -0
  173. package/dist/src/utils/printers.d.ts.map +1 -0
  174. package/dist/src/utils/printers.js +76 -0
  175. package/dist/src/utils/validationMessages.d.ts +18 -0
  176. package/dist/src/utils/validationMessages.d.ts.map +1 -0
  177. package/dist/src/utils/validationMessages.js +43 -0
  178. package/dist/src/validators/BuiltInValidators.d.ts +61 -0
  179. package/dist/src/validators/BuiltInValidators.d.ts.map +1 -0
  180. package/dist/src/validators/BuiltInValidators.js +66 -0
  181. package/dist/src/validators/InternalParamWrappers.d.ts +5 -0
  182. package/dist/src/validators/InternalParamWrappers.d.ts.map +1 -0
  183. package/dist/src/validators/InternalParamWrappers.js +5 -0
  184. package/dist/src/validators/ParamWrappers.d.ts +11 -0
  185. package/dist/src/validators/ParamWrappers.d.ts.map +1 -0
  186. package/dist/src/validators/ParamWrappers.js +9 -0
  187. package/dist/src/validators/types.d.ts +18 -0
  188. package/dist/src/validators/types.d.ts.map +1 -0
  189. package/dist/src/validators/types.js +2 -0
  190. package/dist/tsconfig.build.tsbuildinfo +1 -0
  191. package/package.json +59 -0
  192. package/src/errors/BaseHttpError.ts +16 -0
  193. package/src/errors/HttpErrorHandler.ts +20 -0
  194. package/src/errors/UserFacingErrors.ts +39 -0
  195. package/src/hooks/authentication/useAuth.ts +8 -0
  196. package/src/hooks/authentication/useOptionalAuth.ts +17 -0
  197. package/src/hooks/useApiEndpoint.spec.ts +11 -0
  198. package/src/hooks/useApiEndpoint.ts +10 -0
  199. package/src/hooks/useApiHeader/index.ts +1 -0
  200. package/src/hooks/useApiHeader/useApiHeader.spec.data.ts +22 -0
  201. package/src/hooks/useApiHeader/useApiHeader.spec.ts +34 -0
  202. package/src/hooks/useApiHeader/useApiHeader.ts +6 -0
  203. package/src/hooks/useCookieParams.spec.ts +174 -0
  204. package/src/hooks/useCookieParams.ts +73 -0
  205. package/src/hooks/useExposeApiModel/index.ts +1 -0
  206. package/src/hooks/useExposeApiModel/useExposeApiModel.spec.data.ts +48 -0
  207. package/src/hooks/useExposeApiModel/useExposeApiModel.spec.ts +388 -0
  208. package/src/hooks/useExposeApiModel/useExposeApiModel.ts +9 -0
  209. package/src/hooks/useHeaderParams.spec.ts +186 -0
  210. package/src/hooks/useHeaderParams.ts +83 -0
  211. package/src/hooks/usePathParams.spec.ts +161 -0
  212. package/src/hooks/usePathParams.ts +89 -0
  213. package/src/hooks/useQueryParams.spec.ts +224 -0
  214. package/src/hooks/useQueryParams.ts +73 -0
  215. package/src/hooks/useRequestBody.spec.ts +215 -0
  216. package/src/hooks/useRequestBody.ts +94 -0
  217. package/src/hooks/useRequestRawBody.spec.ts +154 -0
  218. package/src/hooks/useRequestRawBody.ts +56 -0
  219. package/src/index.ts +17 -0
  220. package/src/openapi/analyzerModule/analyzerModule.ts +228 -0
  221. package/src/openapi/analyzerModule/nodeParsers.ts +648 -0
  222. package/src/openapi/analyzerModule/parseEndpoint.ts +305 -0
  223. package/src/openapi/analyzerModule/parseExposedModels.ts +34 -0
  224. package/src/openapi/analyzerModule/test/openApiAnalyzer.spec.data.ts +521 -0
  225. package/src/openapi/analyzerModule/test/openApiAnalyzer.spec.ts +1043 -0
  226. package/src/openapi/analyzerModule/types.ts +72 -0
  227. package/src/openapi/discoveryModule/discoverImports/discoverImports.ts +43 -0
  228. package/src/openapi/discoveryModule/discoverRouterFiles/data/testRouterA.spec.data.ts +7 -0
  229. package/src/openapi/discoveryModule/discoverRouterFiles/data/testRouterB.spec.data.ts +7 -0
  230. package/src/openapi/discoveryModule/discoverRouterFiles/discoverRouterFiles.spec.ts +36 -0
  231. package/src/openapi/discoveryModule/discoverRouterFiles/discoverRouterFiles.ts +80 -0
  232. package/src/openapi/discoveryModule/discoverRouters/discoverRouters.spec.data.ts +42 -0
  233. package/src/openapi/discoveryModule/discoverRouters/discoverRouters.spec.ts +18 -0
  234. package/src/openapi/discoveryModule/discoverRouters/discoverRouters.ts +39 -0
  235. package/src/openapi/discoveryModule/index.ts +2 -0
  236. package/src/openapi/generatorModule/generateComponentSchemas.ts +12 -0
  237. package/src/openapi/generatorModule/generatePaths.ts +138 -0
  238. package/src/openapi/generatorModule/generatorModule.ts +17 -0
  239. package/src/openapi/generatorModule/getSchema.ts +169 -0
  240. package/src/openapi/generatorModule/index.ts +4 -0
  241. package/src/openapi/generatorModule/test/openApiGenerator.spec.data.ts +1119 -0
  242. package/src/openapi/generatorModule/test/openApiGenerator.spec.ts +783 -0
  243. package/src/openapi/initOpenApiEngine.ts +20 -0
  244. package/src/openapi/manager/OpenApiManager.ts +153 -0
  245. package/src/openapi/router/OpenApiRouter.ts +11 -0
  246. package/src/openapi/types.ts +86 -0
  247. package/src/router/Router.ts +123 -0
  248. package/src/router/responseValueToJson.ts +6 -0
  249. package/src/setupTests.ts +3 -0
  250. package/src/test/TestAppRouter.ts +76 -0
  251. package/src/test/app.spec.ts +130 -0
  252. package/src/test/app.ts +43 -0
  253. package/src/utils/TypeUtils.ts +51 -0
  254. package/src/utils/loadTestData.ts +15 -0
  255. package/src/utils/mockContext.ts +86 -0
  256. package/src/utils/nameOf.ts +7 -0
  257. package/src/utils/object.spec.ts +27 -0
  258. package/src/utils/object.ts +17 -0
  259. package/src/utils/printers.spec.ts +103 -0
  260. package/src/utils/printers.ts +49 -0
  261. package/src/utils/validationMessages.ts +65 -0
  262. package/src/validators/BuiltInValidators.ts +64 -0
  263. package/src/validators/InternalParamWrappers.ts +14 -0
  264. package/src/validators/ParamWrappers.ts +22 -0
  265. package/src/validators/types.ts +35 -0
  266. package/tsconfig.build.json +15 -0
  267. package/tsconfig.json +29 -0
  268. package/vite.config.ts +16 -0
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useRequestRawBody = void 0;
4
+ const UserFacingErrors_1 = require("../errors/UserFacingErrors");
5
+ const validationMessages_1 = require("../utils/validationMessages");
6
+ const useRequestRawBody = (ctx, validator) => {
7
+ const providedBody = ctx.request.rawBody;
8
+ const isOptional = validator.optional;
9
+ if (!isOptional && !providedBody) {
10
+ throw new UserFacingErrors_1.ValidationError((0, validationMessages_1.getMissingRawBodyMessage)(validator));
11
+ }
12
+ if (isOptional && !providedBody) {
13
+ return undefined;
14
+ }
15
+ const validationResult = (() => {
16
+ try {
17
+ const prevalidatorSuccess = !validator.prevalidate || validator.prevalidate(providedBody);
18
+ const parsedValue = validator.parse(providedBody);
19
+ const validatorSuccess = !validator.validate || validator.validate(parsedValue);
20
+ return {
21
+ validated: prevalidatorSuccess && validatorSuccess,
22
+ parsedValue,
23
+ };
24
+ }
25
+ catch (error) {
26
+ return { validated: false };
27
+ }
28
+ })();
29
+ if (!validationResult.validated) {
30
+ throw new UserFacingErrors_1.ValidationError((0, validationMessages_1.getFailedRawBodyValidationMessage)(validator));
31
+ }
32
+ return validationResult.parsedValue;
33
+ };
34
+ exports.useRequestRawBody = useRequestRawBody;
@@ -0,0 +1,18 @@
1
+ export * from './errors/HttpErrorHandler';
2
+ export * from './errors/UserFacingErrors';
3
+ export * from './hooks/authentication/useAuth';
4
+ export * from './hooks/authentication/useOptionalAuth';
5
+ export * from './hooks/useApiEndpoint';
6
+ export * from './hooks/useApiHeader/useApiHeader';
7
+ export * from './hooks/useCookieParams';
8
+ export * from './hooks/useExposeApiModel';
9
+ export * from './hooks/useHeaderParams';
10
+ export * from './hooks/usePathParams';
11
+ export * from './hooks/useQueryParams';
12
+ export * from './hooks/useRequestBody';
13
+ export * from './hooks/useRequestRawBody';
14
+ export * from './openapi/initOpenApiEngine';
15
+ export * from './router/Router';
16
+ export * from './validators/BuiltInValidators';
17
+ export * from './validators/ParamWrappers';
18
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,2BAA2B,CAAA;AACzC,cAAc,2BAA2B,CAAA;AACzC,cAAc,gCAAgC,CAAA;AAC9C,cAAc,wCAAwC,CAAA;AACtD,cAAc,wBAAwB,CAAA;AACtC,cAAc,mCAAmC,CAAA;AACjD,cAAc,yBAAyB,CAAA;AACvC,cAAc,2BAA2B,CAAA;AACzC,cAAc,yBAAyB,CAAA;AACvC,cAAc,uBAAuB,CAAA;AACrC,cAAc,wBAAwB,CAAA;AACtC,cAAc,wBAAwB,CAAA;AACtC,cAAc,2BAA2B,CAAA;AACzC,cAAc,6BAA6B,CAAA;AAC3C,cAAc,iBAAiB,CAAA;AAC/B,cAAc,gCAAgC,CAAA;AAC9C,cAAc,4BAA4B,CAAA"}
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./errors/HttpErrorHandler"), exports);
18
+ __exportStar(require("./errors/UserFacingErrors"), exports);
19
+ __exportStar(require("./hooks/authentication/useAuth"), exports);
20
+ __exportStar(require("./hooks/authentication/useOptionalAuth"), exports);
21
+ __exportStar(require("./hooks/useApiEndpoint"), exports);
22
+ __exportStar(require("./hooks/useApiHeader/useApiHeader"), exports);
23
+ __exportStar(require("./hooks/useCookieParams"), exports);
24
+ __exportStar(require("./hooks/useExposeApiModel"), exports);
25
+ __exportStar(require("./hooks/useHeaderParams"), exports);
26
+ __exportStar(require("./hooks/usePathParams"), exports);
27
+ __exportStar(require("./hooks/useQueryParams"), exports);
28
+ __exportStar(require("./hooks/useRequestBody"), exports);
29
+ __exportStar(require("./hooks/useRequestRawBody"), exports);
30
+ __exportStar(require("./openapi/initOpenApiEngine"), exports);
31
+ __exportStar(require("./router/Router"), exports);
32
+ __exportStar(require("./validators/BuiltInValidators"), exports);
33
+ __exportStar(require("./validators/ParamWrappers"), exports);
@@ -0,0 +1,18 @@
1
+ import { SourceFile } from 'ts-morph';
2
+ import { DiscoveredSourceFile } from '../discoveryModule/discoverRouterFiles/discoverRouterFiles';
3
+ import { ApiDocsHeader } from '../manager/OpenApiManager';
4
+ import { EndpointData, ExposedModelData } from '../types';
5
+ type Props = {
6
+ tsconfigPath: string;
7
+ sourceFilePaths?: string[];
8
+ sourceFileDiscovery?: boolean | FileDiscoveryConfig;
9
+ };
10
+ type FileDiscoveryConfig = {
11
+ rootPath: string;
12
+ };
13
+ export declare const prepareOpenApiSpec: ({ tsconfigPath, sourceFilePaths, sourceFileDiscovery }: Props) => void;
14
+ export declare const analyzeSourceFileEndpoints: (file: DiscoveredSourceFile, filterEndpointPaths?: string[]) => EndpointData[];
15
+ export declare const analyzeSourceFileApiHeader: (sourceFile: SourceFile) => ApiDocsHeader | null;
16
+ export declare const analyzeSourceFileExposedModels: (sourceFile: SourceFile) => ExposedModelData[];
17
+ export {};
18
+ //# sourceMappingURL=analyzerModule.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"analyzerModule.d.ts","sourceRoot":"","sources":["../../../../src/openapi/analyzerModule/analyzerModule.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAc,MAAM,UAAU,CAAA;AAIjD,OAAO,EACN,oBAAoB,EAEpB,MAAM,4DAA4D,CAAA;AAEnE,OAAO,EAAE,aAAa,EAAkB,MAAM,2BAA2B,CAAA;AACzE,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAA;AAKzD,KAAK,KAAK,GAAG;IACZ,YAAY,EAAE,MAAM,CAAA;IACpB,eAAe,CAAC,EAAE,MAAM,EAAE,CAAA;IAC1B,mBAAmB,CAAC,EAAE,OAAO,GAAG,mBAAmB,CAAA;CACnD,CAAA;AAED,KAAK,mBAAmB,GAAG;IAC1B,QAAQ,EAAE,MAAM,CAAA;CAChB,CAAA;AAMD,eAAO,MAAM,kBAAkB,2DAA4D,KAAK,SAkF/F,CAAA;AAED,eAAO,MAAM,0BAA0B,SAChC,oBAAoB,wBACJ,MAAM,EAAE,KAC5B,YAAY,EAqBd,CAAA;AAED,eAAO,MAAM,0BAA0B,eAAgB,UAAU,KAAG,aAAa,GAAG,IAyCnF,CAAA;AAED,eAAO,MAAM,8BAA8B,eAAgB,UAAU,KAAG,gBAAgB,EA4CvF,CAAA"}
@@ -0,0 +1,192 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.analyzeSourceFileExposedModels = exports.analyzeSourceFileApiHeader = exports.analyzeSourceFileEndpoints = exports.prepareOpenApiSpec = void 0;
27
+ const path = __importStar(require("path"));
28
+ const ts_morph_1 = require("ts-morph");
29
+ const ts_morph_2 = require("ts-morph");
30
+ const discoverImports_1 = require("../discoveryModule/discoverImports/discoverImports");
31
+ const discoverRouterFiles_1 = require("../discoveryModule/discoverRouterFiles/discoverRouterFiles");
32
+ const discoverRouters_1 = require("../discoveryModule/discoverRouters/discoverRouters");
33
+ const OpenApiManager_1 = require("../manager/OpenApiManager");
34
+ const nodeParsers_1 = require("./nodeParsers");
35
+ const parseEndpoint_1 = require("./parseEndpoint");
36
+ const parseExposedModels_1 = require("./parseExposedModels");
37
+ const prepareOpenApiSpec = ({ tsconfigPath, sourceFilePaths, sourceFileDiscovery }) => {
38
+ const openApiManager = OpenApiManager_1.OpenApiManager.getInstance();
39
+ if (openApiManager.isReady()) {
40
+ return;
41
+ }
42
+ const project = new ts_morph_2.Project({
43
+ tsConfigFilePath: path.resolve(tsconfigPath),
44
+ });
45
+ const { explicitRouters, discoveredRouterFiles, allSourceFiles } = (() => {
46
+ const sourceFilesToAdd = sourceFilePaths !== null && sourceFilePaths !== void 0 ? sourceFilePaths : [];
47
+ const resolvedSourceFilePaths = sourceFilesToAdd.map((filepath) => path.resolve(filepath));
48
+ const sourceFiles = resolvedSourceFilePaths.map((filePath) => project.getSourceFileOrThrow(filePath));
49
+ const explicitRouters = sourceFiles.flatMap((file) => ({
50
+ fileName: file.getFilePath(),
51
+ sourceFile: file,
52
+ routers: (0, discoverRouters_1.discoverRouters)(file),
53
+ }));
54
+ const { discoveredRouterFiles, discoveredSourceFiles } = (() => {
55
+ if (sourceFileDiscovery === false) {
56
+ return { discoveredRouterFiles: [], discoveredSourceFiles: [] };
57
+ }
58
+ return (0, discoverRouterFiles_1.discoverRouterFiles)({
59
+ targetPath: typeof sourceFileDiscovery === 'object' ? sourceFileDiscovery.rootPath : '.',
60
+ tsConfigPath: tsconfigPath,
61
+ });
62
+ })();
63
+ const allSourceFiles = sourceFiles.reduce((acc, current) => acc.some((r) => r.getFilePath() === current.getFilePath()) ? acc : acc.concat(current), discoveredSourceFiles);
64
+ return { explicitRouters, discoveredRouterFiles, allSourceFiles };
65
+ })();
66
+ const filesToAnalyze = explicitRouters.reduce((acc, current) => (acc.some((r) => r.fileName === current.fileName) ? acc : acc.concat(current)), discoveredRouterFiles);
67
+ const apiHeaders = allSourceFiles
68
+ .flatMap((file) => (0, exports.analyzeSourceFileApiHeader)(file))
69
+ .filter((headers) => !!headers);
70
+ if (apiHeaders.length > 0 && apiHeaders[0]) {
71
+ openApiManager.setHeader(apiHeaders[0]);
72
+ }
73
+ const exposedModels = allSourceFiles.flatMap((file) => (0, exports.analyzeSourceFileExposedModels)(file));
74
+ openApiManager.setExposedModels(exposedModels);
75
+ const endpoints = filesToAnalyze.flatMap((file) => (0, exports.analyzeSourceFileEndpoints)(file));
76
+ openApiManager.setStats({
77
+ discoveredRouterFiles: discoveredRouterFiles.map((file) => ({
78
+ path: file.fileName,
79
+ routers: file.routers.named.map((r) => ({
80
+ name: r,
81
+ endpoints: endpoints
82
+ .filter((e) => e.sourceFilePath === file.fileName)
83
+ .map((e) => `${e.method.toUpperCase()} ${e.path}`),
84
+ })),
85
+ })),
86
+ explicitRouterFiles: explicitRouters.map((file) => ({
87
+ path: file.fileName,
88
+ routers: file.routers.named.map((r) => ({
89
+ name: r,
90
+ endpoints: endpoints
91
+ .filter((e) => e.sourceFilePath === file.fileName)
92
+ .map((e) => `${e.method.toUpperCase()} ${e.path}`),
93
+ })),
94
+ })),
95
+ });
96
+ openApiManager.setEndpoints(endpoints);
97
+ openApiManager.markAsReady();
98
+ };
99
+ exports.prepareOpenApiSpec = prepareOpenApiSpec;
100
+ const analyzeSourceFileEndpoints = (file, filterEndpointPaths) => {
101
+ const endpoints = [];
102
+ file.routers.named.forEach((routerName) => {
103
+ file.sourceFile.forEachChild((node) => {
104
+ var _a, _b;
105
+ const nodeText = node.getText();
106
+ const operations = ['get', 'post', 'put', 'delete', 'del', 'patch'];
107
+ const targetNodes = operations.map((op) => `${routerName}.${op}`);
108
+ if (targetNodes.some((targetNode) => nodeText.includes(targetNode))) {
109
+ const endpointText = (_b = (_a = node.getFirstDescendantByKind(ts_morph_1.SyntaxKind.StringLiteral)) === null || _a === void 0 ? void 0 : _a.getText()) !== null && _b !== void 0 ? _b : '';
110
+ const endpointPath = endpointText.substring(1, endpointText.length - 1);
111
+ if (!!filterEndpointPaths && !filterEndpointPaths.some((path) => endpointPath.includes(path))) {
112
+ return;
113
+ }
114
+ endpoints.push((0, parseEndpoint_1.parseEndpoint)(node, file.fileName));
115
+ }
116
+ });
117
+ });
118
+ return endpoints;
119
+ };
120
+ exports.analyzeSourceFileEndpoints = analyzeSourceFileEndpoints;
121
+ const analyzeSourceFileApiHeader = (sourceFile) => {
122
+ const nameOfUseApiHeader = (0, discoverImports_1.discoverImportedName)({
123
+ sourceFile,
124
+ originalName: 'useApiHeader',
125
+ });
126
+ if (!nameOfUseApiHeader) {
127
+ return null;
128
+ }
129
+ const node = sourceFile
130
+ .forEachChildAsArray()
131
+ .filter((node) => node.isKind(ts_morph_1.SyntaxKind.ExpressionStatement))
132
+ .find((node) => nameOfUseApiHeader && node.getText().startsWith(nameOfUseApiHeader));
133
+ if (!node) {
134
+ return null;
135
+ }
136
+ const targetNode = node.getFirstDescendantByKindOrThrow(ts_morph_1.SyntaxKind.ObjectLiteralExpression);
137
+ const values = (0, nodeParsers_1.getValuesOfObjectLiteral)(targetNode);
138
+ const collapseObject = (v) => {
139
+ if (typeof v === 'string') {
140
+ return v;
141
+ }
142
+ if (Array.isArray(v) && v.every((value) => typeof value === 'string')) {
143
+ return v;
144
+ }
145
+ return v.reduce((acc, current) => {
146
+ if (typeof current === 'string') {
147
+ return acc;
148
+ }
149
+ return Object.assign(Object.assign({}, acc), { [current.identifier]: collapseObject(current.value) });
150
+ }, {});
151
+ };
152
+ return collapseObject(values);
153
+ };
154
+ exports.analyzeSourceFileApiHeader = analyzeSourceFileApiHeader;
155
+ const analyzeSourceFileExposedModels = (sourceFile) => {
156
+ const models = [];
157
+ const nameOfUseExposeApiModel = (0, discoverImports_1.discoverImportedName)({
158
+ sourceFile,
159
+ originalName: 'useExposeApiModel',
160
+ });
161
+ const nameOfUseExposeNamedApiModels = (0, discoverImports_1.discoverImportedName)({
162
+ sourceFile,
163
+ originalName: 'useExposeNamedApiModels',
164
+ });
165
+ sourceFile
166
+ .forEachChildAsArray()
167
+ .filter((node) => node.isKind(ts_morph_1.SyntaxKind.ExpressionStatement))
168
+ .map((node) => {
169
+ if (nameOfUseExposeApiModel && node.getText().startsWith(nameOfUseExposeApiModel)) {
170
+ const callExpressionNode = node.getFirstChild();
171
+ const syntaxListChildren = (callExpressionNode === null || callExpressionNode === void 0 ? void 0 : callExpressionNode.getChildrenOfKind(ts_morph_1.SyntaxKind.SyntaxList)) || [];
172
+ const firstChild = syntaxListChildren[0].getFirstChild();
173
+ if (!firstChild) {
174
+ return;
175
+ }
176
+ models.push((0, parseExposedModels_1.parseExposedModel)(firstChild));
177
+ return;
178
+ }
179
+ if (nameOfUseExposeNamedApiModels && node.getText().startsWith(nameOfUseExposeNamedApiModels)) {
180
+ const callExpressionNode = node.getFirstChild();
181
+ const syntaxListChildren = (callExpressionNode === null || callExpressionNode === void 0 ? void 0 : callExpressionNode.getChildrenOfKind(ts_morph_1.SyntaxKind.SyntaxList)) || [];
182
+ const firstChild = syntaxListChildren[0].getFirstChild();
183
+ if (!firstChild) {
184
+ return;
185
+ }
186
+ const parsedModels = (0, parseExposedModels_1.parseNamedExposedModels)(firstChild);
187
+ parsedModels.forEach((model) => models.push(model));
188
+ }
189
+ });
190
+ return models;
191
+ };
192
+ exports.analyzeSourceFileExposedModels = analyzeSourceFileExposedModels;
@@ -0,0 +1,19 @@
1
+ import { Node, PropertyAccessExpression, PropertyAssignment, PropertySignature, ShorthandPropertyAssignment, ts, Type, TypeReferenceNode } from 'ts-morph';
2
+ import { ShapeOfProperty, ShapeOfType } from './types';
3
+ export declare const findNodeImplementation: (node: Node) => Node;
4
+ export declare const findPropertyAssignmentValueNode: (node: PropertyAssignment | TypeReferenceNode | PropertySignature | PropertyAccessExpression | ShorthandPropertyAssignment) => Node;
5
+ export declare const getTypeReferenceShape: (node: TypeReferenceNode) => ShapeOfType['shape'];
6
+ export declare const getRecursiveNodeShape: (nodeOrReference: Node) => ShapeOfType['shape'];
7
+ export declare const getShapeOfValidatorLiteral: (objectLiteralNode: Node<ts.ObjectLiteralExpression>) => (ShapeOfProperty & {
8
+ description: string;
9
+ errorMessage: string;
10
+ })[];
11
+ export declare const getValidatorPropertyShape: (innerLiteralNode: Node) => ShapeOfType['shape'];
12
+ export declare const getValidatorPropertyOptionality: (node: Node) => boolean;
13
+ export declare const getValidatorPropertyStringValue: (nodeOrReference: Node, name: 'description' | 'errorMessage') => string;
14
+ export declare const getProperTypeShape: (typeOrPromise: Type, atLocation: Node, stack?: Type[]) => ShapeOfType['shape'];
15
+ export declare const getValuesOfObjectLiteral: (objectLiteralNode: Node<ts.ObjectLiteralExpression>) => {
16
+ identifier: string;
17
+ value: string | string[] | unknown[];
18
+ }[];
19
+ //# sourceMappingURL=nodeParsers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nodeParsers.d.ts","sourceRoot":"","sources":["../../../../src/openapi/analyzerModule/nodeParsers.ts"],"names":[],"mappings":"AACA,OAAO,EACN,IAAI,EACJ,wBAAwB,EACxB,kBAAkB,EAClB,iBAAiB,EACjB,2BAA2B,EAE3B,EAAE,EACF,IAAI,EACJ,iBAAiB,EACjB,MAAM,UAAU,CAAA;AAGjB,OAAO,EAAE,eAAe,EAAE,WAAW,EAAqB,MAAM,SAAS,CAAA;AAEzE,eAAO,MAAM,sBAAsB,SAAU,IAAI,KAAG,IAyBnD,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,CAkIhF,CAAA;AAED,eAAO,MAAM,0BAA0B,sBACnB,KAAK,GAAG,uBAAuB,CAAC,KACjD,CAAC,eAAe,GAAG;IAAE,WAAW,EAAE,MAAM,CAAC;IAAC,YAAY,EAAE,MAAM,CAAA;CAAE,CAAC,EA8BnE,CAAA;AAED,eAAO,MAAM,yBAAyB,qBAAsB,IAAI,KAAG,WAAW,CAAC,OAAO,CAoFrF,CAAA;AAED,eAAO,MAAM,+BAA+B,SAAU,IAAI,KAAG,OA4B5D,CAAA;AAED,eAAO,MAAM,+BAA+B,oBAC1B,IAAI,QACf,aAAa,GAAG,cAAc,KAClC,MAuDF,CAAA;AAWD,eAAO,MAAM,kBAAkB,kBACf,IAAI,cACP,IAAI,UACT,IAAI,EAAE,KACX,WAAW,CAAC,OAAO,CAuLrB,CAAA;AAiBD,eAAO,MAAM,wBAAwB,sBAAuB,KAAK,GAAG,uBAAuB,CAAC;;;GAmB3F,CAAA"}