@goast/kotlin 0.4.7-beta2 → 0.4.7

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 (519) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +45 -45
  3. package/assets/client/okhttp3/ApiClient.kt +250 -250
  4. package/esm/_dnt.test_polyfills.d.ts +29 -0
  5. package/esm/_dnt.test_polyfills.d.ts.map +1 -0
  6. package/esm/_dnt.test_polyfills.js +31 -0
  7. package/esm/_dnt.test_shims.d.ts +6 -0
  8. package/esm/_dnt.test_shims.d.ts.map +1 -0
  9. package/esm/_dnt.test_shims.js +61 -0
  10. package/esm/deps/jsr.io/@std/assert/1.0.9/assertion_error.d.ts +26 -0
  11. package/esm/deps/jsr.io/@std/assert/1.0.9/assertion_error.d.ts.map +1 -0
  12. package/esm/deps/jsr.io/@std/assert/1.0.9/assertion_error.js +30 -0
  13. package/esm/deps/jsr.io/@std/assert/1.0.9/equal.d.ts +17 -0
  14. package/esm/deps/jsr.io/@std/assert/1.0.9/equal.d.ts.map +1 -0
  15. package/esm/deps/jsr.io/@std/assert/1.0.9/equal.js +183 -0
  16. package/esm/deps/jsr.io/@std/assert/1.0.9/equals.d.ts +35 -0
  17. package/esm/deps/jsr.io/@std/assert/1.0.9/equals.d.ts.map +1 -0
  18. package/esm/deps/jsr.io/@std/assert/1.0.9/equals.js +58 -0
  19. package/esm/deps/jsr.io/@std/assert/1.0.9/false.d.ts +18 -0
  20. package/esm/deps/jsr.io/@std/assert/1.0.9/false.d.ts.map +1 -0
  21. package/esm/deps/jsr.io/@std/assert/1.0.9/false.js +22 -0
  22. package/esm/deps/jsr.io/@std/assert/1.0.9/instance_of.d.ts +23 -0
  23. package/esm/deps/jsr.io/@std/assert/1.0.9/instance_of.d.ts.map +1 -0
  24. package/esm/deps/jsr.io/@std/assert/1.0.9/instance_of.js +53 -0
  25. package/esm/deps/jsr.io/@std/assert/1.0.9/is_error.d.ts +25 -0
  26. package/esm/deps/jsr.io/@std/assert/1.0.9/is_error.d.ts.map +1 -0
  27. package/esm/deps/jsr.io/@std/assert/1.0.9/is_error.js +54 -0
  28. package/esm/deps/jsr.io/@std/assert/1.0.9/match.d.ts +18 -0
  29. package/esm/deps/jsr.io/@std/assert/1.0.9/match.d.ts.map +1 -0
  30. package/esm/deps/jsr.io/@std/assert/1.0.9/match.js +26 -0
  31. package/esm/deps/jsr.io/@std/assert/1.0.9/not_instance_of.d.ts +20 -0
  32. package/esm/deps/jsr.io/@std/assert/1.0.9/not_instance_of.d.ts.map +1 -0
  33. package/esm/deps/jsr.io/@std/assert/1.0.9/not_instance_of.js +29 -0
  34. package/esm/deps/jsr.io/@std/assert/1.0.9/not_match.d.ts +18 -0
  35. package/esm/deps/jsr.io/@std/assert/1.0.9/not_match.d.ts.map +1 -0
  36. package/esm/deps/jsr.io/@std/assert/1.0.9/not_match.js +26 -0
  37. package/esm/deps/jsr.io/@std/assert/1.0.9/not_strict_equals.d.ts +23 -0
  38. package/esm/deps/jsr.io/@std/assert/1.0.9/not_strict_equals.d.ts.map +1 -0
  39. package/esm/deps/jsr.io/@std/assert/1.0.9/not_strict_equals.js +32 -0
  40. package/esm/deps/jsr.io/@std/assert/1.0.9/rejects.d.ts +42 -0
  41. package/esm/deps/jsr.io/@std/assert/1.0.9/rejects.d.ts.map +1 -0
  42. package/esm/deps/jsr.io/@std/assert/1.0.9/rejects.js +53 -0
  43. package/esm/deps/jsr.io/@std/assert/1.0.9/strict_equals.d.ts +24 -0
  44. package/esm/deps/jsr.io/@std/assert/1.0.9/strict_equals.d.ts.map +1 -0
  45. package/esm/deps/jsr.io/@std/assert/1.0.9/strict_equals.js +57 -0
  46. package/esm/deps/jsr.io/@std/expect/1.0.9/_assert_equals.d.ts +20 -0
  47. package/esm/deps/jsr.io/@std/expect/1.0.9/_assert_equals.d.ts.map +1 -0
  48. package/esm/deps/jsr.io/@std/expect/1.0.9/_assert_equals.js +29 -0
  49. package/esm/deps/jsr.io/@std/expect/1.0.9/_assert_not_equals.d.ts +17 -0
  50. package/esm/deps/jsr.io/@std/expect/1.0.9/_assert_not_equals.d.ts.map +1 -0
  51. package/esm/deps/jsr.io/@std/expect/1.0.9/_assert_not_equals.js +26 -0
  52. package/esm/deps/jsr.io/@std/expect/1.0.9/_assertions.d.ts +4 -0
  53. package/esm/deps/jsr.io/@std/expect/1.0.9/_assertions.d.ts.map +1 -0
  54. package/esm/deps/jsr.io/@std/expect/1.0.9/_assertions.js +13 -0
  55. package/esm/deps/jsr.io/@std/expect/1.0.9/_asymmetric_matchers.d.ts +46 -0
  56. package/esm/deps/jsr.io/@std/expect/1.0.9/_asymmetric_matchers.d.ts.map +1 -0
  57. package/esm/deps/jsr.io/@std/expect/1.0.9/_asymmetric_matchers.js +160 -0
  58. package/esm/deps/jsr.io/@std/expect/1.0.9/_build_message.d.ts +6 -0
  59. package/esm/deps/jsr.io/@std/expect/1.0.9/_build_message.d.ts.map +1 -0
  60. package/esm/deps/jsr.io/@std/expect/1.0.9/_build_message.js +29 -0
  61. package/esm/deps/jsr.io/@std/expect/1.0.9/_custom_equality_tester.d.ts +4 -0
  62. package/esm/deps/jsr.io/@std/expect/1.0.9/_custom_equality_tester.d.ts.map +1 -0
  63. package/esm/deps/jsr.io/@std/expect/1.0.9/_custom_equality_tester.js +11 -0
  64. package/esm/deps/jsr.io/@std/expect/1.0.9/_equal.d.ts +9 -0
  65. package/esm/deps/jsr.io/@std/expect/1.0.9/_equal.d.ts.map +1 -0
  66. package/esm/deps/jsr.io/@std/expect/1.0.9/_equal.js +191 -0
  67. package/esm/deps/jsr.io/@std/expect/1.0.9/_extend.d.ts +4 -0
  68. package/esm/deps/jsr.io/@std/expect/1.0.9/_extend.d.ts.map +1 -0
  69. package/esm/deps/jsr.io/@std/expect/1.0.9/_extend.js +11 -0
  70. package/esm/deps/jsr.io/@std/expect/1.0.9/_inspect_args.d.ts +3 -0
  71. package/esm/deps/jsr.io/@std/expect/1.0.9/_inspect_args.d.ts.map +1 -0
  72. package/esm/deps/jsr.io/@std/expect/1.0.9/_inspect_args.js +12 -0
  73. package/esm/deps/jsr.io/@std/expect/1.0.9/_matchers.d.ts +34 -0
  74. package/esm/deps/jsr.io/@std/expect/1.0.9/_matchers.d.ts.map +1 -0
  75. package/esm/deps/jsr.io/@std/expect/1.0.9/_matchers.js +568 -0
  76. package/esm/deps/jsr.io/@std/expect/1.0.9/_mock_util.d.ts +11 -0
  77. package/esm/deps/jsr.io/@std/expect/1.0.9/_mock_util.d.ts.map +1 -0
  78. package/esm/deps/jsr.io/@std/expect/1.0.9/_mock_util.js +10 -0
  79. package/esm/deps/jsr.io/@std/expect/1.0.9/_serializer.d.ts +4 -0
  80. package/esm/deps/jsr.io/@std/expect/1.0.9/_serializer.d.ts.map +1 -0
  81. package/esm/deps/jsr.io/@std/expect/1.0.9/_serializer.js +10 -0
  82. package/esm/deps/jsr.io/@std/expect/1.0.9/_types.d.ts +839 -0
  83. package/esm/deps/jsr.io/@std/expect/1.0.9/_types.d.ts.map +1 -0
  84. package/esm/deps/jsr.io/@std/expect/1.0.9/_types.js +3 -0
  85. package/esm/deps/jsr.io/@std/expect/1.0.9/_utils.d.ts +9 -0
  86. package/esm/deps/jsr.io/@std/expect/1.0.9/_utils.d.ts.map +1 -0
  87. package/esm/deps/jsr.io/@std/expect/1.0.9/_utils.js +218 -0
  88. package/esm/deps/jsr.io/@std/expect/1.0.9/expect.d.ts +60 -0
  89. package/esm/deps/jsr.io/@std/expect/1.0.9/expect.d.ts.map +1 -0
  90. package/esm/deps/jsr.io/@std/expect/1.0.9/expect.js +523 -0
  91. package/esm/deps/jsr.io/@std/internal/1.0.5/assertion_state.d.ts +160 -0
  92. package/esm/deps/jsr.io/@std/internal/1.0.5/assertion_state.d.ts.map +1 -0
  93. package/esm/deps/jsr.io/@std/internal/1.0.5/assertion_state.js +199 -0
  94. package/esm/deps/jsr.io/@std/internal/1.0.5/build_message.d.ts +82 -0
  95. package/esm/deps/jsr.io/@std/internal/1.0.5/build_message.d.ts.map +1 -0
  96. package/esm/deps/jsr.io/@std/internal/1.0.5/build_message.js +111 -0
  97. package/esm/deps/jsr.io/@std/internal/1.0.5/diff.d.ts +140 -0
  98. package/esm/deps/jsr.io/@std/internal/1.0.5/diff.d.ts.map +1 -0
  99. package/esm/deps/jsr.io/@std/internal/1.0.5/diff.js +277 -0
  100. package/esm/deps/jsr.io/@std/internal/1.0.5/diff_str.d.ts +99 -0
  101. package/esm/deps/jsr.io/@std/internal/1.0.5/diff_str.d.ts.map +1 -0
  102. package/esm/deps/jsr.io/@std/internal/1.0.5/diff_str.js +180 -0
  103. package/esm/deps/jsr.io/@std/internal/1.0.5/format.d.ts +2 -0
  104. package/esm/deps/jsr.io/@std/internal/1.0.5/format.d.ts.map +1 -0
  105. package/esm/deps/jsr.io/@std/internal/1.0.5/format.js +37 -0
  106. package/esm/deps/jsr.io/@std/internal/1.0.5/styles.d.ts +159 -0
  107. package/esm/deps/jsr.io/@std/internal/1.0.5/styles.d.ts.map +1 -0
  108. package/esm/deps/jsr.io/@std/internal/1.0.5/styles.js +207 -0
  109. package/esm/deps/jsr.io/@std/internal/1.0.5/types.d.ts +16 -0
  110. package/esm/deps/jsr.io/@std/internal/1.0.5/types.d.ts.map +1 -0
  111. package/esm/deps/jsr.io/@std/internal/1.0.5/types.js +2 -0
  112. package/esm/deps/jsr.io/@std/testing/1.0.6/_mock_utils.d.ts +15 -0
  113. package/esm/deps/jsr.io/@std/testing/1.0.6/_mock_utils.d.ts.map +1 -0
  114. package/esm/deps/jsr.io/@std/testing/1.0.6/_mock_utils.js +35 -0
  115. package/esm/deps/jsr.io/@std/testing/1.0.6/_test_suite.d.ts +74 -0
  116. package/esm/deps/jsr.io/@std/testing/1.0.6/_test_suite.d.ts.map +1 -0
  117. package/esm/deps/jsr.io/@std/testing/1.0.6/_test_suite.js +350 -0
  118. package/esm/deps/jsr.io/@std/testing/1.0.6/bdd.d.ts +736 -0
  119. package/esm/deps/jsr.io/@std/testing/1.0.6/bdd.d.ts.map +1 -0
  120. package/esm/deps/jsr.io/@std/testing/1.0.6/bdd.js +652 -0
  121. package/esm/deps/jsr.io/@std/testing/1.0.6/mock.d.ts +674 -0
  122. package/esm/deps/jsr.io/@std/testing/1.0.6/mock.d.ts.map +1 -0
  123. package/esm/deps/jsr.io/@std/testing/1.0.6/mock.js +1083 -0
  124. package/esm/src/ast/nodes/annotation.test.d.ts +2 -0
  125. package/esm/src/ast/nodes/annotation.test.d.ts.map +1 -0
  126. package/esm/src/ast/nodes/annotation.test.js +56 -0
  127. package/esm/src/ast/nodes/argument.test.d.ts +2 -0
  128. package/esm/src/ast/nodes/argument.test.d.ts.map +1 -0
  129. package/esm/src/ast/nodes/argument.test.js +33 -0
  130. package/esm/src/ast/nodes/call.test.d.ts +2 -0
  131. package/esm/src/ast/nodes/call.test.d.ts.map +1 -0
  132. package/esm/src/ast/nodes/call.test.js +35 -0
  133. package/esm/src/ast/nodes/class.test.d.ts +2 -0
  134. package/esm/src/ast/nodes/class.test.d.ts.map +1 -0
  135. package/esm/src/ast/nodes/class.test.js +219 -0
  136. package/esm/src/ast/nodes/constructor.test.d.ts +2 -0
  137. package/esm/src/ast/nodes/constructor.test.d.ts.map +1 -0
  138. package/esm/src/ast/nodes/constructor.test.js +139 -0
  139. package/esm/src/ast/nodes/doc-tag.test.d.ts +2 -0
  140. package/esm/src/ast/nodes/doc-tag.test.d.ts.map +1 -0
  141. package/esm/src/ast/nodes/doc-tag.test.js +67 -0
  142. package/esm/src/ast/nodes/doc.test.d.ts +2 -0
  143. package/esm/src/ast/nodes/doc.test.d.ts.map +1 -0
  144. package/esm/src/ast/nodes/doc.test.js +33 -0
  145. package/esm/src/ast/nodes/enum-value.test.d.ts +2 -0
  146. package/esm/src/ast/nodes/enum-value.test.d.ts.map +1 -0
  147. package/esm/src/ast/nodes/enum-value.test.js +115 -0
  148. package/esm/src/ast/nodes/enum.test.d.ts +2 -0
  149. package/esm/src/ast/nodes/enum.test.d.ts.map +1 -0
  150. package/esm/src/ast/nodes/enum.test.js +129 -0
  151. package/esm/src/ast/nodes/function.test.d.ts +2 -0
  152. package/esm/src/ast/nodes/function.test.d.ts.map +1 -0
  153. package/esm/src/ast/nodes/function.test.js +160 -0
  154. package/esm/src/ast/nodes/generic-parameter.test.d.ts +2 -0
  155. package/esm/src/ast/nodes/generic-parameter.test.d.ts.map +1 -0
  156. package/esm/src/ast/nodes/generic-parameter.test.js +49 -0
  157. package/esm/src/ast/nodes/init-block.test.d.ts +2 -0
  158. package/esm/src/ast/nodes/init-block.test.d.ts.map +1 -0
  159. package/esm/src/ast/nodes/init-block.test.js +28 -0
  160. package/esm/src/ast/nodes/interface.test.d.ts +2 -0
  161. package/esm/src/ast/nodes/interface.test.d.ts.map +1 -0
  162. package/esm/src/ast/nodes/interface.test.js +121 -0
  163. package/esm/src/ast/nodes/object.test.d.ts +2 -0
  164. package/esm/src/ast/nodes/object.test.d.ts.map +1 -0
  165. package/esm/src/ast/nodes/object.test.js +78 -0
  166. package/esm/src/ast/nodes/parameter.test.d.ts +2 -0
  167. package/esm/src/ast/nodes/parameter.test.d.ts.map +1 -0
  168. package/esm/src/ast/nodes/parameter.test.js +152 -0
  169. package/esm/src/ast/nodes/property.test.d.ts +2 -0
  170. package/esm/src/ast/nodes/property.test.d.ts.map +1 -0
  171. package/esm/src/ast/nodes/property.test.js +206 -0
  172. package/esm/src/ast/nodes/reference.test.d.ts +2 -0
  173. package/esm/src/ast/nodes/reference.test.d.ts.map +1 -0
  174. package/esm/src/ast/nodes/reference.test.js +36 -0
  175. package/esm/src/ast/nodes/string.test.d.ts +2 -0
  176. package/esm/src/ast/nodes/string.test.d.ts.map +1 -0
  177. package/esm/src/ast/nodes/string.test.js +48 -0
  178. package/esm/src/ast/references/spring.d.ts +0 -1
  179. package/esm/src/ast/references/spring.d.ts.map +1 -1
  180. package/esm/src/ast/references/spring.js +0 -2
  181. package/esm/src/generators/services/okhttp3-clients/okhttp3-client-generator.js +26 -26
  182. package/esm/src/generators/services/spring-controllers/args.d.ts +2 -17
  183. package/esm/src/generators/services/spring-controllers/args.d.ts.map +1 -1
  184. package/esm/src/generators/services/spring-controllers/models.d.ts +1 -2
  185. package/esm/src/generators/services/spring-controllers/models.d.ts.map +1 -1
  186. package/esm/src/generators/services/spring-controllers/models.js +1 -2
  187. package/esm/src/generators/services/spring-controllers/spring-controller-generator.d.ts +2 -4
  188. package/esm/src/generators/services/spring-controllers/spring-controller-generator.d.ts.map +1 -1
  189. package/esm/src/generators/services/spring-controllers/spring-controller-generator.js +17 -78
  190. package/esm/src/import-collection.test.d.ts +2 -0
  191. package/esm/src/import-collection.test.d.ts.map +1 -0
  192. package/esm/src/import-collection.test.js +99 -0
  193. package/esm/tests/openapi-models.test.d.ts +2 -0
  194. package/esm/tests/openapi-models.test.d.ts.map +1 -0
  195. package/esm/tests/openapi-models.test.js +45 -0
  196. package/package.json +1 -2
  197. package/script/_dnt.test_polyfills.d.ts +29 -0
  198. package/script/_dnt.test_polyfills.d.ts.map +1 -0
  199. package/script/_dnt.test_polyfills.js +32 -0
  200. package/script/_dnt.test_shims.d.ts +6 -0
  201. package/script/_dnt.test_shims.d.ts.map +1 -0
  202. package/script/_dnt.test_shims.js +65 -0
  203. package/script/deps/jsr.io/@std/assert/1.0.9/assertion_error.d.ts +26 -0
  204. package/script/deps/jsr.io/@std/assert/1.0.9/assertion_error.d.ts.map +1 -0
  205. package/script/deps/jsr.io/@std/assert/1.0.9/assertion_error.js +34 -0
  206. package/script/deps/jsr.io/@std/assert/1.0.9/equal.d.ts +17 -0
  207. package/script/deps/jsr.io/@std/assert/1.0.9/equal.d.ts.map +1 -0
  208. package/script/deps/jsr.io/@std/assert/1.0.9/equal.js +187 -0
  209. package/script/deps/jsr.io/@std/assert/1.0.9/equals.d.ts +35 -0
  210. package/script/deps/jsr.io/@std/assert/1.0.9/equals.d.ts.map +1 -0
  211. package/script/deps/jsr.io/@std/assert/1.0.9/equals.js +61 -0
  212. package/script/deps/jsr.io/@std/assert/1.0.9/false.d.ts +18 -0
  213. package/script/deps/jsr.io/@std/assert/1.0.9/false.d.ts.map +1 -0
  214. package/script/deps/jsr.io/@std/assert/1.0.9/false.js +25 -0
  215. package/script/deps/jsr.io/@std/assert/1.0.9/instance_of.d.ts +23 -0
  216. package/script/deps/jsr.io/@std/assert/1.0.9/instance_of.d.ts.map +1 -0
  217. package/script/deps/jsr.io/@std/assert/1.0.9/instance_of.js +56 -0
  218. package/script/deps/jsr.io/@std/assert/1.0.9/is_error.d.ts +25 -0
  219. package/script/deps/jsr.io/@std/assert/1.0.9/is_error.d.ts.map +1 -0
  220. package/script/deps/jsr.io/@std/assert/1.0.9/is_error.js +57 -0
  221. package/script/deps/jsr.io/@std/assert/1.0.9/match.d.ts +18 -0
  222. package/script/deps/jsr.io/@std/assert/1.0.9/match.d.ts.map +1 -0
  223. package/script/deps/jsr.io/@std/assert/1.0.9/match.js +29 -0
  224. package/script/deps/jsr.io/@std/assert/1.0.9/not_instance_of.d.ts +20 -0
  225. package/script/deps/jsr.io/@std/assert/1.0.9/not_instance_of.d.ts.map +1 -0
  226. package/script/deps/jsr.io/@std/assert/1.0.9/not_instance_of.js +32 -0
  227. package/script/deps/jsr.io/@std/assert/1.0.9/not_match.d.ts +18 -0
  228. package/script/deps/jsr.io/@std/assert/1.0.9/not_match.d.ts.map +1 -0
  229. package/script/deps/jsr.io/@std/assert/1.0.9/not_match.js +29 -0
  230. package/script/deps/jsr.io/@std/assert/1.0.9/not_strict_equals.d.ts +23 -0
  231. package/script/deps/jsr.io/@std/assert/1.0.9/not_strict_equals.d.ts.map +1 -0
  232. package/script/deps/jsr.io/@std/assert/1.0.9/not_strict_equals.js +35 -0
  233. package/script/deps/jsr.io/@std/assert/1.0.9/rejects.d.ts +42 -0
  234. package/script/deps/jsr.io/@std/assert/1.0.9/rejects.d.ts.map +1 -0
  235. package/script/deps/jsr.io/@std/assert/1.0.9/rejects.js +56 -0
  236. package/script/deps/jsr.io/@std/assert/1.0.9/strict_equals.d.ts +24 -0
  237. package/script/deps/jsr.io/@std/assert/1.0.9/strict_equals.d.ts.map +1 -0
  238. package/script/deps/jsr.io/@std/assert/1.0.9/strict_equals.js +60 -0
  239. package/script/deps/jsr.io/@std/expect/1.0.9/_assert_equals.d.ts +20 -0
  240. package/script/deps/jsr.io/@std/expect/1.0.9/_assert_equals.d.ts.map +1 -0
  241. package/script/deps/jsr.io/@std/expect/1.0.9/_assert_equals.js +32 -0
  242. package/script/deps/jsr.io/@std/expect/1.0.9/_assert_not_equals.d.ts +17 -0
  243. package/script/deps/jsr.io/@std/expect/1.0.9/_assert_not_equals.d.ts.map +1 -0
  244. package/script/deps/jsr.io/@std/expect/1.0.9/_assert_not_equals.js +29 -0
  245. package/script/deps/jsr.io/@std/expect/1.0.9/_assertions.d.ts +4 -0
  246. package/script/deps/jsr.io/@std/expect/1.0.9/_assertions.d.ts.map +1 -0
  247. package/script/deps/jsr.io/@std/expect/1.0.9/_assertions.js +18 -0
  248. package/script/deps/jsr.io/@std/expect/1.0.9/_asymmetric_matchers.d.ts +46 -0
  249. package/script/deps/jsr.io/@std/expect/1.0.9/_asymmetric_matchers.d.ts.map +1 -0
  250. package/script/deps/jsr.io/@std/expect/1.0.9/_asymmetric_matchers.js +182 -0
  251. package/script/deps/jsr.io/@std/expect/1.0.9/_build_message.d.ts +6 -0
  252. package/script/deps/jsr.io/@std/expect/1.0.9/_build_message.d.ts.map +1 -0
  253. package/script/deps/jsr.io/@std/expect/1.0.9/_build_message.js +33 -0
  254. package/script/deps/jsr.io/@std/expect/1.0.9/_custom_equality_tester.d.ts +4 -0
  255. package/script/deps/jsr.io/@std/expect/1.0.9/_custom_equality_tester.d.ts.map +1 -0
  256. package/script/deps/jsr.io/@std/expect/1.0.9/_custom_equality_tester.js +15 -0
  257. package/script/deps/jsr.io/@std/expect/1.0.9/_equal.d.ts +9 -0
  258. package/script/deps/jsr.io/@std/expect/1.0.9/_equal.d.ts.map +1 -0
  259. package/script/deps/jsr.io/@std/expect/1.0.9/_equal.js +194 -0
  260. package/script/deps/jsr.io/@std/expect/1.0.9/_extend.d.ts +4 -0
  261. package/script/deps/jsr.io/@std/expect/1.0.9/_extend.d.ts.map +1 -0
  262. package/script/deps/jsr.io/@std/expect/1.0.9/_extend.js +15 -0
  263. package/script/deps/jsr.io/@std/expect/1.0.9/_inspect_args.d.ts +3 -0
  264. package/script/deps/jsr.io/@std/expect/1.0.9/_inspect_args.d.ts.map +1 -0
  265. package/script/deps/jsr.io/@std/expect/1.0.9/_inspect_args.js +17 -0
  266. package/script/deps/jsr.io/@std/expect/1.0.9/_matchers.d.ts +34 -0
  267. package/script/deps/jsr.io/@std/expect/1.0.9/_matchers.d.ts.map +1 -0
  268. package/script/deps/jsr.io/@std/expect/1.0.9/_matchers.js +602 -0
  269. package/script/deps/jsr.io/@std/expect/1.0.9/_mock_util.d.ts +11 -0
  270. package/script/deps/jsr.io/@std/expect/1.0.9/_mock_util.d.ts.map +1 -0
  271. package/script/deps/jsr.io/@std/expect/1.0.9/_mock_util.js +14 -0
  272. package/script/deps/jsr.io/@std/expect/1.0.9/_serializer.d.ts +4 -0
  273. package/script/deps/jsr.io/@std/expect/1.0.9/_serializer.d.ts.map +1 -0
  274. package/script/deps/jsr.io/@std/expect/1.0.9/_serializer.js +14 -0
  275. package/script/deps/jsr.io/@std/expect/1.0.9/_types.d.ts +839 -0
  276. package/script/deps/jsr.io/@std/expect/1.0.9/_types.d.ts.map +1 -0
  277. package/script/deps/jsr.io/@std/expect/1.0.9/_types.js +4 -0
  278. package/script/deps/jsr.io/@std/expect/1.0.9/_utils.d.ts +9 -0
  279. package/script/deps/jsr.io/@std/expect/1.0.9/_utils.d.ts.map +1 -0
  280. package/script/deps/jsr.io/@std/expect/1.0.9/_utils.js +226 -0
  281. package/script/deps/jsr.io/@std/expect/1.0.9/expect.d.ts +60 -0
  282. package/script/deps/jsr.io/@std/expect/1.0.9/expect.d.ts.map +1 -0
  283. package/script/deps/jsr.io/@std/expect/1.0.9/expect.js +527 -0
  284. package/script/deps/jsr.io/@std/internal/1.0.5/assertion_state.d.ts +160 -0
  285. package/script/deps/jsr.io/@std/internal/1.0.5/assertion_state.d.ts.map +1 -0
  286. package/script/deps/jsr.io/@std/internal/1.0.5/assertion_state.js +204 -0
  287. package/script/deps/jsr.io/@std/internal/1.0.5/build_message.d.ts +82 -0
  288. package/script/deps/jsr.io/@std/internal/1.0.5/build_message.d.ts.map +1 -0
  289. package/script/deps/jsr.io/@std/internal/1.0.5/build_message.js +116 -0
  290. package/script/deps/jsr.io/@std/internal/1.0.5/diff.d.ts +140 -0
  291. package/script/deps/jsr.io/@std/internal/1.0.5/diff.d.ts.map +1 -0
  292. package/script/deps/jsr.io/@std/internal/1.0.5/diff.js +284 -0
  293. package/script/deps/jsr.io/@std/internal/1.0.5/diff_str.d.ts +99 -0
  294. package/script/deps/jsr.io/@std/internal/1.0.5/diff_str.d.ts.map +1 -0
  295. package/script/deps/jsr.io/@std/internal/1.0.5/diff_str.js +186 -0
  296. package/script/deps/jsr.io/@std/internal/1.0.5/format.d.ts +2 -0
  297. package/script/deps/jsr.io/@std/internal/1.0.5/format.d.ts.map +1 -0
  298. package/script/deps/jsr.io/@std/internal/1.0.5/format.js +41 -0
  299. package/script/deps/jsr.io/@std/internal/1.0.5/styles.d.ts +159 -0
  300. package/script/deps/jsr.io/@std/internal/1.0.5/styles.d.ts.map +1 -0
  301. package/script/deps/jsr.io/@std/internal/1.0.5/styles.js +220 -0
  302. package/script/deps/jsr.io/@std/internal/1.0.5/types.d.ts +16 -0
  303. package/script/deps/jsr.io/@std/internal/1.0.5/types.d.ts.map +1 -0
  304. package/script/deps/jsr.io/@std/internal/1.0.5/types.js +3 -0
  305. package/script/deps/jsr.io/@std/testing/1.0.6/_mock_utils.d.ts +15 -0
  306. package/script/deps/jsr.io/@std/testing/1.0.6/_mock_utils.d.ts.map +1 -0
  307. package/script/deps/jsr.io/@std/testing/1.0.6/_mock_utils.js +41 -0
  308. package/script/deps/jsr.io/@std/testing/1.0.6/_test_suite.d.ts +74 -0
  309. package/script/deps/jsr.io/@std/testing/1.0.6/_test_suite.d.ts.map +1 -0
  310. package/script/deps/jsr.io/@std/testing/1.0.6/_test_suite.js +355 -0
  311. package/script/deps/jsr.io/@std/testing/1.0.6/bdd.d.ts +736 -0
  312. package/script/deps/jsr.io/@std/testing/1.0.6/bdd.d.ts.map +1 -0
  313. package/script/deps/jsr.io/@std/testing/1.0.6/bdd.js +663 -0
  314. package/script/deps/jsr.io/@std/testing/1.0.6/mock.d.ts +674 -0
  315. package/script/deps/jsr.io/@std/testing/1.0.6/mock.d.ts.map +1 -0
  316. package/script/deps/jsr.io/@std/testing/1.0.6/mock.js +1102 -0
  317. package/script/src/ast/nodes/annotation.test.d.ts +2 -0
  318. package/script/src/ast/nodes/annotation.test.d.ts.map +1 -0
  319. package/script/src/ast/nodes/annotation.test.js +58 -0
  320. package/script/src/ast/nodes/argument.test.d.ts +2 -0
  321. package/script/src/ast/nodes/argument.test.d.ts.map +1 -0
  322. package/script/src/ast/nodes/argument.test.js +35 -0
  323. package/script/src/ast/nodes/call.test.d.ts +2 -0
  324. package/script/src/ast/nodes/call.test.d.ts.map +1 -0
  325. package/script/src/ast/nodes/call.test.js +37 -0
  326. package/script/src/ast/nodes/class.test.d.ts +2 -0
  327. package/script/src/ast/nodes/class.test.d.ts.map +1 -0
  328. package/script/src/ast/nodes/class.test.js +221 -0
  329. package/script/src/ast/nodes/constructor.test.d.ts +2 -0
  330. package/script/src/ast/nodes/constructor.test.d.ts.map +1 -0
  331. package/script/src/ast/nodes/constructor.test.js +141 -0
  332. package/script/src/ast/nodes/doc-tag.test.d.ts +2 -0
  333. package/script/src/ast/nodes/doc-tag.test.d.ts.map +1 -0
  334. package/script/src/ast/nodes/doc-tag.test.js +69 -0
  335. package/script/src/ast/nodes/doc.test.d.ts +2 -0
  336. package/script/src/ast/nodes/doc.test.d.ts.map +1 -0
  337. package/script/src/ast/nodes/doc.test.js +35 -0
  338. package/script/src/ast/nodes/enum-value.test.d.ts +2 -0
  339. package/script/src/ast/nodes/enum-value.test.d.ts.map +1 -0
  340. package/script/src/ast/nodes/enum-value.test.js +117 -0
  341. package/script/src/ast/nodes/enum.test.d.ts +2 -0
  342. package/script/src/ast/nodes/enum.test.d.ts.map +1 -0
  343. package/script/src/ast/nodes/enum.test.js +131 -0
  344. package/script/src/ast/nodes/function.test.d.ts +2 -0
  345. package/script/src/ast/nodes/function.test.d.ts.map +1 -0
  346. package/script/src/ast/nodes/function.test.js +162 -0
  347. package/script/src/ast/nodes/generic-parameter.test.d.ts +2 -0
  348. package/script/src/ast/nodes/generic-parameter.test.d.ts.map +1 -0
  349. package/script/src/ast/nodes/generic-parameter.test.js +51 -0
  350. package/script/src/ast/nodes/init-block.test.d.ts +2 -0
  351. package/script/src/ast/nodes/init-block.test.d.ts.map +1 -0
  352. package/script/src/ast/nodes/init-block.test.js +30 -0
  353. package/script/src/ast/nodes/interface.test.d.ts +2 -0
  354. package/script/src/ast/nodes/interface.test.d.ts.map +1 -0
  355. package/script/src/ast/nodes/interface.test.js +123 -0
  356. package/script/src/ast/nodes/object.test.d.ts +2 -0
  357. package/script/src/ast/nodes/object.test.d.ts.map +1 -0
  358. package/script/src/ast/nodes/object.test.js +80 -0
  359. package/script/src/ast/nodes/parameter.test.d.ts +2 -0
  360. package/script/src/ast/nodes/parameter.test.d.ts.map +1 -0
  361. package/script/src/ast/nodes/parameter.test.js +154 -0
  362. package/script/src/ast/nodes/property.test.d.ts +2 -0
  363. package/script/src/ast/nodes/property.test.d.ts.map +1 -0
  364. package/script/src/ast/nodes/property.test.js +208 -0
  365. package/script/src/ast/nodes/reference.test.d.ts +2 -0
  366. package/script/src/ast/nodes/reference.test.d.ts.map +1 -0
  367. package/script/src/ast/nodes/reference.test.js +38 -0
  368. package/script/src/ast/nodes/string.test.d.ts +2 -0
  369. package/script/src/ast/nodes/string.test.d.ts.map +1 -0
  370. package/script/src/ast/nodes/string.test.js +50 -0
  371. package/script/src/ast/references/spring.d.ts +0 -1
  372. package/script/src/ast/references/spring.d.ts.map +1 -1
  373. package/script/src/ast/references/spring.js +1 -3
  374. package/script/src/generators/services/okhttp3-clients/okhttp3-client-generator.js +26 -26
  375. package/script/src/generators/services/spring-controllers/args.d.ts +2 -17
  376. package/script/src/generators/services/spring-controllers/args.d.ts.map +1 -1
  377. package/script/src/generators/services/spring-controllers/models.d.ts +1 -2
  378. package/script/src/generators/services/spring-controllers/models.d.ts.map +1 -1
  379. package/script/src/generators/services/spring-controllers/models.js +1 -2
  380. package/script/src/generators/services/spring-controllers/spring-controller-generator.d.ts +2 -4
  381. package/script/src/generators/services/spring-controllers/spring-controller-generator.d.ts.map +1 -1
  382. package/script/src/generators/services/spring-controllers/spring-controller-generator.js +18 -79
  383. package/script/src/import-collection.test.d.ts +2 -0
  384. package/script/src/import-collection.test.d.ts.map +1 -0
  385. package/script/src/import-collection.test.js +101 -0
  386. package/script/tests/openapi-models.test.d.ts +2 -0
  387. package/script/tests/openapi-models.test.d.ts.map +1 -0
  388. package/script/tests/openapi-models.test.js +48 -0
  389. package/src/_dnt.test_polyfills.ts +70 -0
  390. package/src/_dnt.test_shims.ts +64 -0
  391. package/src/deps/jsr.io/@std/assert/1.0.9/assertion_error.ts +31 -0
  392. package/src/deps/jsr.io/@std/assert/1.0.9/equal.ts +210 -0
  393. package/src/deps/jsr.io/@std/assert/1.0.9/equals.ts +65 -0
  394. package/src/deps/jsr.io/@std/assert/1.0.9/false.ts +26 -0
  395. package/src/deps/jsr.io/@std/assert/1.0.9/instance_of.ts +64 -0
  396. package/src/deps/jsr.io/@std/assert/1.0.9/is_error.ts +65 -0
  397. package/src/deps/jsr.io/@std/assert/1.0.9/match.ts +30 -0
  398. package/src/deps/jsr.io/@std/assert/1.0.9/not_instance_of.ts +33 -0
  399. package/src/deps/jsr.io/@std/assert/1.0.9/not_match.ts +30 -0
  400. package/src/deps/jsr.io/@std/assert/1.0.9/not_strict_equals.ts +42 -0
  401. package/src/deps/jsr.io/@std/assert/1.0.9/rejects.ts +123 -0
  402. package/src/deps/jsr.io/@std/assert/1.0.9/strict_equals.ts +67 -0
  403. package/src/deps/jsr.io/@std/expect/1.0.9/_assert_equals.ts +38 -0
  404. package/src/deps/jsr.io/@std/expect/1.0.9/_assert_not_equals.ts +35 -0
  405. package/src/deps/jsr.io/@std/expect/1.0.9/_assertions.ts +18 -0
  406. package/src/deps/jsr.io/@std/expect/1.0.9/_asymmetric_matchers.ts +193 -0
  407. package/src/deps/jsr.io/@std/expect/1.0.9/_build_message.ts +51 -0
  408. package/src/deps/jsr.io/@std/expect/1.0.9/_custom_equality_tester.ts +19 -0
  409. package/src/deps/jsr.io/@std/expect/1.0.9/_equal.ts +230 -0
  410. package/src/deps/jsr.io/@std/expect/1.0.9/_extend.ts +16 -0
  411. package/src/deps/jsr.io/@std/expect/1.0.9/_inspect_args.ts +15 -0
  412. package/src/deps/jsr.io/@std/expect/1.0.9/_matchers.ts +838 -0
  413. package/src/deps/jsr.io/@std/expect/1.0.9/_mock_util.ts +22 -0
  414. package/src/deps/jsr.io/@std/expect/1.0.9/_serializer.ts +15 -0
  415. package/src/deps/jsr.io/@std/expect/1.0.9/_types.ts +919 -0
  416. package/src/deps/jsr.io/@std/expect/1.0.9/_utils.ts +283 -0
  417. package/src/deps/jsr.io/@std/expect/1.0.9/expect.ts +620 -0
  418. package/src/deps/jsr.io/@std/internal/1.0.5/assertion_state.ts +214 -0
  419. package/src/deps/jsr.io/@std/internal/1.0.5/build_message.ts +134 -0
  420. package/src/deps/jsr.io/@std/internal/1.0.5/diff.ts +317 -0
  421. package/src/deps/jsr.io/@std/internal/1.0.5/diff_str.ts +204 -0
  422. package/src/deps/jsr.io/@std/internal/1.0.5/format.ts +39 -0
  423. package/src/deps/jsr.io/@std/internal/1.0.5/styles.ts +233 -0
  424. package/src/deps/jsr.io/@std/internal/1.0.5/types.ts +18 -0
  425. package/src/deps/jsr.io/@std/testing/1.0.6/_mock_utils.ts +43 -0
  426. package/src/deps/jsr.io/@std/testing/1.0.6/_test_suite.ts +410 -0
  427. package/src/deps/jsr.io/@std/testing/1.0.6/bdd.ts +1285 -0
  428. package/src/deps/jsr.io/@std/testing/1.0.6/mock.ts +1807 -0
  429. package/src/mod.ts +8 -0
  430. package/src/src/assets.ts +9 -0
  431. package/src/src/ast/_index.ts +66 -0
  432. package/src/src/ast/common.ts +1 -0
  433. package/src/src/ast/index.ts +1 -0
  434. package/src/src/ast/node.ts +10 -0
  435. package/src/src/ast/nodes/annotation.test.ts +69 -0
  436. package/src/src/ast/nodes/annotation.ts +79 -0
  437. package/src/src/ast/nodes/argument.test.ts +41 -0
  438. package/src/src/ast/nodes/argument.ts +62 -0
  439. package/src/src/ast/nodes/call.test.ts +44 -0
  440. package/src/src/ast/nodes/call.ts +66 -0
  441. package/src/src/ast/nodes/class.test.ts +274 -0
  442. package/src/src/ast/nodes/class.ts +178 -0
  443. package/src/src/ast/nodes/collection-literal.ts +49 -0
  444. package/src/src/ast/nodes/constructor.test.ts +178 -0
  445. package/src/src/ast/nodes/constructor.ts +126 -0
  446. package/src/src/ast/nodes/doc-tag.test.ts +84 -0
  447. package/src/src/ast/nodes/doc-tag.ts +138 -0
  448. package/src/src/ast/nodes/doc.test.ts +42 -0
  449. package/src/src/ast/nodes/doc.ts +111 -0
  450. package/src/src/ast/nodes/enum-value.test.ts +146 -0
  451. package/src/src/ast/nodes/enum-value.ts +100 -0
  452. package/src/src/ast/nodes/enum.test.ts +167 -0
  453. package/src/src/ast/nodes/enum.ts +163 -0
  454. package/src/src/ast/nodes/function.test.ts +194 -0
  455. package/src/src/ast/nodes/function.ts +176 -0
  456. package/src/src/ast/nodes/generic-parameter.test.ts +60 -0
  457. package/src/src/ast/nodes/generic-parameter.ts +54 -0
  458. package/src/src/ast/nodes/init-block.test.ts +36 -0
  459. package/src/src/ast/nodes/init-block.ts +38 -0
  460. package/src/src/ast/nodes/interface.test.ts +151 -0
  461. package/src/src/ast/nodes/interface.ts +133 -0
  462. package/src/src/ast/nodes/lambda-type.ts +68 -0
  463. package/src/src/ast/nodes/lambda.ts +68 -0
  464. package/src/src/ast/nodes/object.test.ts +101 -0
  465. package/src/src/ast/nodes/object.ts +102 -0
  466. package/src/src/ast/nodes/parameter.test.ts +191 -0
  467. package/src/src/ast/nodes/parameter.ts +118 -0
  468. package/src/src/ast/nodes/property.test.ts +253 -0
  469. package/src/src/ast/nodes/property.ts +225 -0
  470. package/src/src/ast/nodes/reference.test.ts +47 -0
  471. package/src/src/ast/nodes/reference.ts +178 -0
  472. package/src/src/ast/nodes/string.test.ts +61 -0
  473. package/src/src/ast/nodes/string.ts +114 -0
  474. package/src/src/ast/nodes/types.ts +23 -0
  475. package/src/src/ast/references/index.ts +8 -0
  476. package/src/src/ast/references/jackson.ts +16 -0
  477. package/src/src/ast/references/jakarta.ts +10 -0
  478. package/src/src/ast/references/java.ts +19 -0
  479. package/src/src/ast/references/kotlin.ts +40 -0
  480. package/src/src/ast/references/okhttp3.ts +5 -0
  481. package/src/src/ast/references/reactor.ts +5 -0
  482. package/src/src/ast/references/spring.ts +58 -0
  483. package/src/src/ast/references/swagger.ts +23 -0
  484. package/src/src/ast/utils/get-kotlin-builder-options.ts +19 -0
  485. package/src/src/ast/utils/to-kt-node.ts +31 -0
  486. package/src/src/ast/utils/write-kt-annotations.ts +15 -0
  487. package/src/src/ast/utils/write-kt-arguments.ts +45 -0
  488. package/src/src/ast/utils/write-kt-enum-values.ts +27 -0
  489. package/src/src/ast/utils/write-kt-generic-parameters.ts +12 -0
  490. package/src/src/ast/utils/write-kt-members.ts +25 -0
  491. package/src/src/ast/utils/write-kt-node.ts +37 -0
  492. package/src/src/ast/utils/write-kt-parameters.ts +25 -0
  493. package/src/src/common-results.ts +4 -0
  494. package/src/src/config.ts +41 -0
  495. package/src/src/file-builder.ts +108 -0
  496. package/src/src/generators/file-generator.ts +29 -0
  497. package/src/src/generators/index.ts +4 -0
  498. package/src/src/generators/models/args.ts +128 -0
  499. package/src/src/generators/models/index.ts +4 -0
  500. package/src/src/generators/models/model-generator.ts +602 -0
  501. package/src/src/generators/models/models-generator.ts +65 -0
  502. package/src/src/generators/models/models.ts +95 -0
  503. package/src/src/generators/services/okhttp3-clients/args.ts +78 -0
  504. package/src/src/generators/services/okhttp3-clients/index.ts +4 -0
  505. package/src/src/generators/services/okhttp3-clients/models.ts +62 -0
  506. package/src/src/generators/services/okhttp3-clients/okhttp3-client-generator.ts +557 -0
  507. package/src/src/generators/services/okhttp3-clients/okhttp3-clients-generator.ts +130 -0
  508. package/src/src/generators/services/okhttp3-clients/refs.ts +55 -0
  509. package/src/src/generators/services/spring-controllers/args.ts +73 -0
  510. package/src/src/generators/services/spring-controllers/index.ts +4 -0
  511. package/src/src/generators/services/spring-controllers/models.ts +60 -0
  512. package/src/src/generators/services/spring-controllers/spring-controller-generator.ts +659 -0
  513. package/src/src/generators/services/spring-controllers/spring-controllers-generator.ts +70 -0
  514. package/src/src/import-collection.test.ts +116 -0
  515. package/src/src/import-collection.ts +98 -0
  516. package/src/src/types.ts +3 -0
  517. package/src/src/utils.ts +39 -0
  518. package/src/tests/openapi-models.test.ts +63 -0
  519. package/test_runner.js +227 -0
@@ -0,0 +1,659 @@
1
+
2
+ import fs from 'fs-extra';
3
+
4
+ import {
5
+ type ApiEndpoint,
6
+ type ApiParameter,
7
+ type AppendValueGroup,
8
+ appendValueGroup,
9
+ builderTemplate as s,
10
+ createOverwriteProxy,
11
+ type MaybePromise,
12
+ notNullish,
13
+ resolveAnyOfAndAllOf,
14
+ SourceBuilder,
15
+ toCasing,
16
+ } from '@goast/core';
17
+
18
+ import { kt } from '../../../ast/index.js';
19
+ import type { KotlinImport } from '../../../common-results.js';
20
+ import { KotlinFileBuilder } from '../../../file-builder.js';
21
+ import type { ApiParameterWithMultipartInfo } from '../../../types.js';
22
+ import { modifyString } from '../../../utils.js';
23
+ import { KotlinFileGenerator } from '../../file-generator.js';
24
+ import type { DefaultKotlinSpringControllerGeneratorArgs as Args } from './index.js';
25
+ import type { KotlinServiceGeneratorContext, KotlinServiceGeneratorOutput } from './models.js';
26
+
27
+ type Context = KotlinServiceGeneratorContext;
28
+ type Output = KotlinServiceGeneratorOutput;
29
+ type Builder = KotlinFileBuilder;
30
+
31
+ export interface KotlinSpringControllerGenerator<TOutput extends Output = Output> {
32
+ generate(ctx: Context): MaybePromise<TOutput>;
33
+ }
34
+
35
+ export class DefaultKotlinSpringControllerGenerator extends KotlinFileGenerator<Context, Output>
36
+ implements KotlinSpringControllerGenerator {
37
+ generate(ctx: KotlinServiceGeneratorContext): MaybePromise<KotlinServiceGeneratorOutput> {
38
+ const packageName = this.getPackageName(ctx, {});
39
+ const dirPath = this.getDirectoryPath(ctx, { packageName });
40
+ fs.ensureDirSync(dirPath);
41
+
42
+ console.log(`Generating service ${ctx.service.id} to ${dirPath}...`);
43
+ return {
44
+ apiInterface: this.generateApiInterfaceFile(ctx, { dirPath, packageName }),
45
+ apiController: this.generateApiControllerFile(ctx, { dirPath, packageName }),
46
+ apiDelegate: this.generateApiDelegateInterfaceFile(ctx, { dirPath, packageName }),
47
+ };
48
+ }
49
+
50
+ // #region API Interface
51
+ protected generateApiInterfaceFile(ctx: Context, args: Args.GenerateApiInterfaceFile): KotlinImport {
52
+ const { dirPath, packageName } = args;
53
+ const typeName = this.getApiInterfaceName(ctx, {});
54
+ const fileName = `${typeName}.kt`;
55
+ const filePath = `${dirPath}/${fileName}`;
56
+ console.log(` Generating API interface ${typeName} to ${fileName}...`);
57
+
58
+ const builder = new KotlinFileBuilder(packageName, ctx.config);
59
+ builder.append(this.getApiInterfaceFileContent(ctx, { interfaceName: typeName }));
60
+ fs.writeFileSync(filePath, builder.toString());
61
+
62
+ return { typeName, packageName };
63
+ }
64
+
65
+ protected getApiInterfaceFileContent(ctx: Context, args: Args.GetApiinterfaceFileContent): AppendValueGroup<Builder> {
66
+ const { interfaceName } = args;
67
+
68
+ return appendValueGroup([this.getApiInterface(ctx, { interfaceName })], '\n');
69
+ }
70
+
71
+ protected getApiInterface(ctx: Context, args: Args.GetApiInterface): kt.Interface<Builder> {
72
+ const { interfaceName } = args;
73
+
74
+ return kt.interface(interfaceName, {
75
+ annotations: this.getApiInterfaceAnnotations(ctx),
76
+ members: this.getApiInterfaceMembers(ctx),
77
+ companionObject: kt.object({
78
+ members: ctx.service.endpoints.map((endpoint) =>
79
+ kt.property(this.getPathConstantName(ctx, { endpoint }), {
80
+ const: true,
81
+ default: kt.string(this.getEndpointPath(ctx, { endpoint })),
82
+ })
83
+ ),
84
+ }),
85
+ });
86
+ }
87
+
88
+ private getApiInterfaceAnnotations(ctx: Context): kt.Annotation<Builder>[] {
89
+ const validated = kt.annotation(kt.refs.spring.validated());
90
+ const requestMapping = kt.annotation(kt.refs.spring.requestMapping(), [
91
+ kt.argument(this.getControllerRequestMapping(ctx, { prefix: 'api' })),
92
+ ]);
93
+ return [validated, requestMapping];
94
+ }
95
+
96
+ private getApiInterfaceMembers(ctx: Context): kt.InterfaceMember<Builder>[] {
97
+ const members: kt.InterfaceMember<Builder>[] = [];
98
+ const delegateInterfaceName = this.getApiDelegateInterfaceName(ctx, {});
99
+
100
+ members.push(
101
+ kt.function('getDelegate', {
102
+ returnType: delegateInterfaceName,
103
+ singleExpression: true,
104
+ body: kt.object({
105
+ implements: [delegateInterfaceName],
106
+ }),
107
+ }),
108
+ );
109
+
110
+ ctx.service.endpoints.forEach((endpoint) => {
111
+ members.push(this.getApiInterfaceEndpointMethod(ctx, { endpoint }));
112
+ });
113
+
114
+ return members;
115
+ }
116
+
117
+ protected getApiInterfaceEndpointMethod(
118
+ ctx: Context,
119
+ args: Args.GetApiInterfaceEndpointMethod,
120
+ ): kt.Function<Builder> {
121
+ const { endpoint } = args;
122
+ const parameters = this.getAllParameters(ctx, { endpoint });
123
+
124
+ return kt.function(toCasing(endpoint.name, ctx.config.functionNameCasing), {
125
+ suspend: true,
126
+ annotations: this.getApiInterfaceEndpointMethodAnnnotations(ctx, endpoint),
127
+ parameters: parameters.map((parameter) => this.getApiInterfaceEndpointMethodParameter(ctx, endpoint, parameter)),
128
+ returnType: kt.refs.spring.responseEntity([this.getResponseType(ctx, { endpoint })]),
129
+ body: this.getApiInterfaceEndpointMethodBody(ctx, endpoint, parameters),
130
+ });
131
+ }
132
+
133
+ private getApiInterfaceEndpointMethodAnnnotations(ctx: Context, endpoint: ApiEndpoint): kt.Annotation<Builder>[] {
134
+ const annotations: kt.Annotation<Builder>[] = [];
135
+
136
+ if (ctx.config.addSwaggerAnnotations) {
137
+ annotations.push(
138
+ kt.annotation(kt.refs.swagger.operation(), [
139
+ endpoint.summary ? kt.argument.named('summary', kt.string(endpoint.summary?.trim())) : null,
140
+ kt.argument.named('operationId', kt.string(endpoint.name)),
141
+ endpoint.description ? kt.argument.named('description', kt.string(endpoint.description?.trim())) : null,
142
+ endpoint.deprecated !== undefined ? kt.argument.named('deprecated', kt.toNode(endpoint.deprecated)) : null,
143
+ ]),
144
+ );
145
+
146
+ if (endpoint.responses.length > 0) {
147
+ annotations.push(
148
+ kt.annotation(kt.refs.swagger.apiResponses(), [
149
+ kt.argument.named(
150
+ 'value',
151
+ kt.collectionLiteral(
152
+ endpoint.responses.map((response) =>
153
+ kt.call(kt.refs.swagger.apiResponse(), [
154
+ kt.argument.named('responseCode', kt.string(response.statusCode?.toString())),
155
+ response.description
156
+ ? kt.argument.named('description', kt.string(response.description?.trim()))
157
+ : null,
158
+ kt.argument.named(
159
+ 'content',
160
+ kt.collectionLiteral(
161
+ (response.contentOptions.length === 0
162
+ ? [{ schema: undefined, type: undefined }]
163
+ : response.contentOptions).map((content) => {
164
+ let schemaType: kt.Type<Builder> = this.getSchemaType(ctx, { schema: content.schema }) ??
165
+ kt.refs.any();
166
+ let isArray = false;
167
+
168
+ if (kt.refs.list.matches(schemaType)) {
169
+ isArray = true;
170
+ schemaType = schemaType.generics[0];
171
+ }
172
+
173
+ let ktSchema = kt.call(kt.refs.swagger.schema(), [
174
+ kt.argument.named('implementation', s<Builder>`${schemaType}::class`),
175
+ ]);
176
+ if (isArray) {
177
+ ktSchema = kt.call(kt.refs.swagger.arraySchema(), [
178
+ kt.argument.named('schema', ktSchema),
179
+ ]);
180
+ }
181
+
182
+ return kt.call(kt.refs.swagger.content(), [
183
+ content.type ? kt.argument.named('mediaType', kt.string(content.type)) : null,
184
+ content.schema ? kt.argument.named(isArray ? 'array' : 'schema', ktSchema) : null,
185
+ ]);
186
+ }),
187
+ ),
188
+ ),
189
+ ])
190
+ ),
191
+ ),
192
+ ),
193
+ ]),
194
+ );
195
+ }
196
+ }
197
+
198
+ const requestMapping = kt.annotation(kt.refs.spring.requestMapping(), [
199
+ kt.argument.named(
200
+ 'method',
201
+ kt.collectionLiteral([kt.call([kt.refs.spring.requestMethod(), endpoint.method.toUpperCase()])]),
202
+ ),
203
+ kt.argument.named('value', kt.collectionLiteral([this.getPathConstantName(ctx, { endpoint })])),
204
+ ]);
205
+ if (endpoint.requestBody && endpoint.requestBody.content.length > 0) {
206
+ requestMapping.arguments.push(
207
+ kt.argument.named(
208
+ 'consumes',
209
+ kt.collectionLiteral(endpoint.requestBody?.content.map((x) => kt.string(x.type))),
210
+ ),
211
+ );
212
+ }
213
+ annotations.push(requestMapping);
214
+
215
+ return annotations;
216
+ }
217
+
218
+ private getApiInterfaceEndpointMethodParameter(
219
+ ctx: Context,
220
+ endpoint: ApiEndpoint,
221
+ parameter: ApiParameterWithMultipartInfo,
222
+ ): kt.Parameter<Builder> {
223
+ const schemaType = this.getSchemaType(ctx, { schema: parameter.schema });
224
+ const result = kt.parameter(
225
+ toCasing(parameter.name, ctx.config.parameterNameCasing),
226
+ this.getParameterType(ctx, { endpoint, parameter }),
227
+ {
228
+ default: parameter.multipart && parameter.schema?.default !== undefined
229
+ ? kt.toNode(parameter.schema?.default)
230
+ : null,
231
+ },
232
+ );
233
+
234
+ if (ctx.config.addSwaggerAnnotations) {
235
+ const annotation = kt.annotation(kt.refs.swagger.parameter(), [
236
+ parameter.multipart ? kt.argument.named('name', kt.string(parameter.multipart.name)) : null,
237
+ parameter.description ? kt.argument.named('description', kt.string(parameter.description?.trim())) : null,
238
+ kt.argument.named('required', parameter.required),
239
+ ]);
240
+ if (parameter.schema?.default !== undefined) {
241
+ annotation.arguments.push(
242
+ kt.argument.named(
243
+ 'schema',
244
+ kt.call(
245
+ [kt.refs.swagger.schema()],
246
+ [kt.argument.named('defaultValue', kt.string(String(parameter.schema?.default)))],
247
+ ),
248
+ ),
249
+ );
250
+ }
251
+ result.annotations.push(annotation);
252
+ }
253
+
254
+ const isCorePackage = !schemaType?.packageName || /^(kotlin|java)(\..*|$)/.test(schemaType.packageName);
255
+ if (!isCorePackage && ctx.config.addJakartaValidationAnnotations) {
256
+ result.annotations.push(kt.annotation(kt.refs.jakarta.valid()));
257
+ }
258
+
259
+ if (parameter.target === 'body' && !parameter.multipart) {
260
+ result.annotations.push(kt.annotation(kt.refs.spring.requestBody()));
261
+ }
262
+
263
+ if (parameter.target === 'query') {
264
+ const annotation = kt.annotation(kt.refs.spring.requestParam(), [
265
+ kt.argument.named('value', kt.string(parameter.name)),
266
+ kt.argument.named('required', parameter.required),
267
+ ]);
268
+ if (parameter.schema?.default !== undefined) {
269
+ annotation.arguments.push(kt.argument.named('defaultValue', kt.string(String(parameter.schema?.default))));
270
+ }
271
+ result.annotations.push(annotation);
272
+ }
273
+
274
+ if (parameter.target === 'path') {
275
+ result.annotations.push(kt.annotation(kt.refs.spring.pathVariable(), [kt.string(parameter.name)]));
276
+ }
277
+
278
+ if (parameter.multipart) {
279
+ result.annotations.push(
280
+ kt.annotation(kt.refs.spring.requestPart(), [
281
+ kt.argument.named('value', kt.string(parameter.multipart.name)),
282
+ kt.argument.named('required', parameter.required),
283
+ ]),
284
+ );
285
+ }
286
+
287
+ return result;
288
+ }
289
+
290
+ private getApiInterfaceEndpointMethodBody(
291
+ ctx: Context,
292
+ endpoint: ApiEndpoint,
293
+ parameters: ApiParameter[],
294
+ ): AppendValueGroup<Builder> {
295
+ return appendValueGroup(
296
+ [
297
+ s`return ${
298
+ kt.call(
299
+ [kt.call(kt.reference('getDelegate'), []), toCasing(endpoint.name, ctx.config.functionNameCasing)],
300
+ parameters.map((x) => toCasing(x.name, ctx.config.parameterNameCasing)),
301
+ )
302
+ }`,
303
+ ],
304
+ '\n',
305
+ );
306
+ }
307
+ // #endregion
308
+
309
+ // #region API Controller
310
+ protected generateApiControllerFile(ctx: Context, args: Args.GenerateApiControllerFile): KotlinImport {
311
+ const { dirPath, packageName } = args;
312
+ const typeName = this.getApiControllerName(ctx, {});
313
+ const fileName = `${typeName}.kt`;
314
+ const filePath = `${dirPath}/${fileName}`;
315
+ console.log(` Generating API controller ${typeName} to ${fileName}...`);
316
+
317
+ const builder = new KotlinFileBuilder(packageName, ctx.config);
318
+ builder.append(this.getApiControllerFileContent(ctx, { controllerName: typeName }));
319
+ fs.writeFileSync(filePath, builder.toString());
320
+
321
+ return { typeName, packageName };
322
+ }
323
+
324
+ protected getApiControllerFileContent(
325
+ ctx: Context,
326
+ args: Args.GetApiControllerFileContent,
327
+ ): AppendValueGroup<Builder> {
328
+ const { controllerName } = args;
329
+
330
+ return appendValueGroup([this.getApiController(ctx, { controllerName })], '\n');
331
+ }
332
+
333
+ protected getApiController(ctx: Context, args: Args.GetApiController): kt.Class<Builder> {
334
+ const { controllerName } = args;
335
+
336
+ return kt.class(controllerName, {
337
+ annotations: this.getApiControllerAnnotations(ctx),
338
+ primaryConstructor: kt.constructor([
339
+ kt.parameter.class(
340
+ 'delegate',
341
+ kt.reference(this.getApiDelegateInterfaceName(ctx, {}), null, { nullable: true }),
342
+ {
343
+ annotations: [kt.annotation(kt.refs.spring.autowired(), [kt.argument.named('required', 'false')])],
344
+ },
345
+ ),
346
+ ]),
347
+ implements: [this.getApiInterfaceName(ctx, {})],
348
+ members: this.getApiControllerMembers(ctx),
349
+ });
350
+ }
351
+
352
+ private getApiControllerAnnotations(ctx: Context): kt.Annotation<Builder>[] {
353
+ const annotations: kt.Annotation<Builder>[] = [];
354
+ if (ctx.config.addJakartaValidationAnnotations) {
355
+ annotations.push(
356
+ kt.annotation(kt.refs.jakarta.generated(), [
357
+ kt.argument.named('value', kt.collectionLiteral([kt.string('com.goast.kotlin.spring-service-generator')])),
358
+ ]),
359
+ );
360
+ }
361
+ annotations.push(kt.annotation(kt.refs.spring.controller()));
362
+ annotations.push(kt.annotation(kt.refs.spring.requestMapping(), [this.getControllerRequestMapping(ctx, {})]));
363
+ return annotations;
364
+ }
365
+
366
+ private getApiControllerMembers(ctx: Context): kt.ClassMember<Builder>[] {
367
+ const delegateInterfaceName = this.getApiDelegateInterfaceName(ctx, {});
368
+
369
+ const delegateProp = kt.property<Builder>('delegate', {
370
+ accessModifier: 'private',
371
+ type: kt.reference(delegateInterfaceName),
372
+ });
373
+
374
+ const initBlock = kt.initBlock<Builder>(
375
+ appendValueGroup(
376
+ [
377
+ s`this.delegate = ${kt.refs.java.optional.infer()}.ofNullable(delegate).orElse(object : ${delegateInterfaceName} {})`,
378
+ ],
379
+ '\n',
380
+ ),
381
+ );
382
+
383
+ const getDelegateFun = kt.function<Builder>('getDelegate', {
384
+ override: true,
385
+ returnType: delegateInterfaceName,
386
+ singleExpression: true,
387
+ body: kt.reference('delegate'),
388
+ });
389
+
390
+ return [delegateProp, initBlock, getDelegateFun];
391
+ }
392
+ // #endregion
393
+
394
+ // #region API Delegate Interface
395
+ protected generateApiDelegateInterfaceFile(ctx: Context, args: Args.GenerateApiDelegateInterfaceFile): KotlinImport {
396
+ const { dirPath, packageName } = args;
397
+ const typeName = this.getApiDelegateInterfaceName(ctx, {});
398
+ const fileName = `${typeName}.kt`;
399
+ const filePath = `${dirPath}/${fileName}`;
400
+ console.log(` Generating API delegate ${typeName} to ${fileName}...`);
401
+
402
+ const builder = new KotlinFileBuilder(packageName, ctx.config);
403
+ builder.append(this.getApiDelegateInterfaceFileContent(ctx, { delegateInterfaceName: typeName }));
404
+ fs.writeFileSync(filePath, builder.toString());
405
+
406
+ return { typeName, packageName };
407
+ }
408
+
409
+ protected getApiDelegateInterfaceFileContent(
410
+ ctx: Context,
411
+ args: Args.GetApiDelegateInterfaceFileContent,
412
+ ): AppendValueGroup<Builder> {
413
+ const { delegateInterfaceName } = args;
414
+
415
+ return appendValueGroup([this.getApiDelegateInterface(ctx, { delegateInterfaceName })], '\n');
416
+ }
417
+
418
+ protected getApiDelegateInterface(ctx: Context, args: Args.GetApiDelegateInterface): kt.Interface<Builder> {
419
+ const { delegateInterfaceName } = args;
420
+
421
+ return kt.interface(delegateInterfaceName, {
422
+ annotations: this.getApiDelegateInterfaceAnnotations(ctx),
423
+ members: this.getApiDelegateInterfaceMembers(ctx),
424
+ });
425
+ }
426
+
427
+ private getApiDelegateInterfaceAnnotations(ctx: Context): kt.Annotation<Builder>[] {
428
+ const annotations: kt.Annotation<Builder>[] = [];
429
+ if (ctx.config.addJakartaValidationAnnotations) {
430
+ annotations.push(
431
+ kt.annotation(kt.refs.jakarta.generated(), [
432
+ kt.argument.named('value', kt.collectionLiteral([kt.string('com.goast.kotlin.spring-service-generator')])),
433
+ ]),
434
+ );
435
+ }
436
+ return annotations;
437
+ }
438
+
439
+ private getApiDelegateInterfaceMembers(ctx: Context): kt.InterfaceMember<Builder>[] {
440
+ const members: kt.InterfaceMember<Builder>[] = [];
441
+
442
+ members.push(
443
+ kt.function('getRequest', {
444
+ returnType: kt.refs.java.optional([kt.refs.spring.nativeWebRequest()]),
445
+ singleExpression: true,
446
+ body: kt.call([kt.refs.java.optional.infer(), 'empty'], []),
447
+ }),
448
+ );
449
+
450
+ ctx.service.endpoints.forEach((endpoint) => {
451
+ members.push(this.getApiDelegateInterfaceEndpointMethod(ctx, { endpoint }));
452
+ });
453
+
454
+ return members;
455
+ }
456
+
457
+ protected getApiDelegateInterfaceEndpointMethod(
458
+ ctx: Context,
459
+ args: Args.GetApiDelegateInterfaceEndpointMethod,
460
+ ): kt.Function<Builder> {
461
+ const { endpoint } = args;
462
+ const parameters = this.getAllParameters(ctx, { endpoint });
463
+
464
+ return kt.function(toCasing(endpoint.name, ctx.config.functionNameCasing), {
465
+ suspend: true,
466
+ parameters: parameters.map((parameter) => {
467
+ return kt.parameter(
468
+ toCasing(parameter.name, ctx.config.parameterNameCasing),
469
+ this.getParameterType(ctx, { endpoint, parameter }),
470
+ );
471
+ }),
472
+ returnType: kt.refs.spring.responseEntity([this.getResponseType(ctx, { endpoint })]),
473
+ body: appendValueGroup(
474
+ [s`return ${kt.refs.spring.responseEntity.infer()}(${kt.refs.spring.httpStatus()}.NOT_IMPLEMENTED)`],
475
+ '\n',
476
+ ),
477
+ });
478
+ }
479
+ // #endregion
480
+
481
+ protected getParameterType(ctx: Context, args: Args.GetParameterType): kt.Type<Builder> {
482
+ const { parameter } = args;
483
+ if (parameter.multipart?.isFile) {
484
+ return kt.refs.spring.filePart();
485
+ }
486
+ const type = this.getTypeUsage(ctx, {
487
+ schema: parameter.schema,
488
+ nullable: (!parameter.required && parameter.schema?.default === undefined) || undefined,
489
+ });
490
+ return parameter.target === 'body' ? adjustListType(ctx, type) : type;
491
+ }
492
+
493
+ protected getResponseType(ctx: Context, args: Args.GetResponseType): kt.Type<Builder> {
494
+ const { endpoint } = args;
495
+ const responseSchemas = endpoint.responses
496
+ .flatMap((x) => x.contentOptions.flatMap((x) => x.schema))
497
+ .filter(notNullish)
498
+ .filter(
499
+ (x, i, a) =>
500
+ a.findIndex((y) => {
501
+ const xType = this.getSchemaType(ctx, { schema: x });
502
+ const yType = this.getSchemaType(ctx, { schema: y });
503
+ return xType?.name === yType?.name && xType?.packageName === yType?.packageName;
504
+ }) === i,
505
+ );
506
+
507
+ if (responseSchemas.length === 1) {
508
+ return adjustListType(ctx, this.getTypeUsage(ctx, { schema: responseSchemas[0], fallback: kt.refs.unit() }));
509
+ } else if (responseSchemas.length === 0) {
510
+ return kt.refs.unit();
511
+ } else {
512
+ return kt.refs.any({ nullable: true });
513
+ }
514
+ }
515
+
516
+ protected getTypeUsage(ctx: Context, args: Args.GetTypeUsage<Builder>): kt.Type<Builder> {
517
+ const { schema, nullable, fallback } = args;
518
+ const type = this.getSchemaType(ctx, { schema });
519
+ return type
520
+ ? createOverwriteProxy(type, { nullable: nullable ?? type.nullable })
521
+ : (fallback ?? kt.refs.any({ nullable }));
522
+ }
523
+
524
+ protected getSchemaType(ctx: Context, args: Args.GetSchemaType): kt.Reference<SourceBuilder> | undefined {
525
+ const { schema } = args;
526
+ return schema && ctx.input.kotlin.models[schema.id].type;
527
+ }
528
+
529
+ protected getControllerRequestMapping(ctx: Context, args: Args.GetControllerRequestMapping): kt.String<Builder> {
530
+ let { prefix } = args;
531
+ const basePath = this.getBasePath(ctx, {});
532
+ prefix ??= `openapi.${toCasing(ctx.service.name, ctx.config.propertyNameCasing)}`;
533
+ return kt.string(`\${${prefix}.base-path:${basePath}}`);
534
+ }
535
+
536
+ protected getBasePath(ctx: Context, _args: Args.GetBasePath): string {
537
+ return modifyString(
538
+ (ctx.service.$src ?? ctx.service.endpoints[0]?.$src)?.document.servers?.[0]?.url ?? '/',
539
+ ctx.config.basePath,
540
+ ctx.service,
541
+ );
542
+ }
543
+
544
+ protected getEndpointPath(ctx: Context, args: Args.GetEndpointPath): string {
545
+ const { endpoint } = args;
546
+ return modifyString(endpoint.path, ctx.config.pathModifier, endpoint);
547
+ }
548
+
549
+ protected getDirectoryPath(ctx: Context, args: Args.GetDirectoryPath): string {
550
+ const { packageName } = args;
551
+ return `${ctx.config.outputDir}/${packageName.replace(/\./g, '/')}`;
552
+ }
553
+
554
+ protected getPathConstantName(ctx: Context, args: Args.GetPathConstantName): string {
555
+ const { endpoint } = args;
556
+ return toCasing(`${endpoint.name}_path`, ctx.config.constantNameCasing);
557
+ }
558
+
559
+ protected getPackageName(ctx: Context, _args: Args.GetPackageName): string {
560
+ const packageSuffix = typeof ctx.config.packageSuffix === 'string'
561
+ ? ctx.config.packageSuffix
562
+ : ctx.config.packageSuffix(ctx.service);
563
+ return ctx.config.packageName + packageSuffix;
564
+ }
565
+
566
+ protected getApiInterfaceName(ctx: Context, _args: Args.GetApiInterfaceName): string {
567
+ return toCasing(ctx.service.name + '_Api', ctx.config.typeNameCasing);
568
+ }
569
+
570
+ protected getApiControllerName(ctx: Context, _args: Args.GetApiControllerName): string {
571
+ return toCasing(ctx.service.name + '_ApiController', ctx.config.typeNameCasing);
572
+ }
573
+
574
+ protected getApiDelegateInterfaceName(ctx: Context, _args: Args.GetApiDelegateInterfaceName): string {
575
+ return toCasing(ctx.service.name + '_ApiDelegate', ctx.config.typeNameCasing);
576
+ }
577
+
578
+ protected getAllParameters(ctx: Context, args: Args.GetAllParameters): ApiParameterWithMultipartInfo[] {
579
+ const { endpoint } = args;
580
+ const parameters = endpoint.parameters.filter(
581
+ (parameter) => parameter.target === 'query' || parameter.target === 'path',
582
+ );
583
+ if (endpoint.requestBody) {
584
+ const content = endpoint.requestBody.content[0];
585
+ let schema = content.schema;
586
+
587
+ if (content.type === 'multipart/form-data') {
588
+ if (schema && schema.kind === 'object') {
589
+ schema = resolveAnyOfAndAllOf(schema, true) ?? schema;
590
+ const properties = schema.properties ?? {};
591
+ for (const [name, property] of properties.entries()) {
592
+ parameters.push(
593
+ Object.assign(
594
+ this.createApiParameter({
595
+ id: `multipart-${name}`,
596
+ name,
597
+ target: 'body',
598
+ schema: property.schema,
599
+ required: schema.required.has(name),
600
+ description: property.schema.description,
601
+ }),
602
+ {
603
+ multipart: {
604
+ name,
605
+ isFile: property.schema.kind === 'string' && property.schema.format === 'binary',
606
+ },
607
+ },
608
+ ),
609
+ );
610
+ }
611
+ }
612
+ } else {
613
+ const schemaType = this.getSchemaType(ctx, { schema });
614
+ const name = !schemaType || /^Any\??$/.test(schemaType.name)
615
+ ? 'body'
616
+ : SourceBuilder.build((b) => kt.reference.write(b, schemaType));
617
+ parameters.push(
618
+ this.createApiParameter({
619
+ id: 'body',
620
+ name,
621
+ target: 'body',
622
+ schema,
623
+ required: endpoint.requestBody.required,
624
+ description: endpoint.requestBody.description,
625
+ }),
626
+ );
627
+ }
628
+ }
629
+
630
+ return parameters;
631
+ }
632
+
633
+ private createApiParameter(data: Partial<ApiParameter> & Pick<ApiParameter, 'id' | 'name' | 'target'>): ApiParameter {
634
+ return {
635
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
636
+ $src: undefined!,
637
+ $ref: undefined,
638
+ schema: undefined,
639
+ required: false,
640
+ description: undefined,
641
+ allowEmptyValue: undefined,
642
+ allowReserved: undefined,
643
+ deprecated: false,
644
+ explode: undefined,
645
+ style: undefined,
646
+ ...data,
647
+ };
648
+ }
649
+ }
650
+
651
+ export function adjustListType<T>(ctx: Context, type: T): T {
652
+ if (!kt.refs.list.matches(type)) return type;
653
+ switch (ctx.config.arrayType) {
654
+ case 'flux':
655
+ return kt.refs.reactor.flux([type.generics[0]]) as T;
656
+ default:
657
+ return type;
658
+ }
659
+ }