@goast/kotlin 0.4.17 → 0.4.18-beta1

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 (523) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +45 -45
  3. package/assets/client/okhttp3/ApiClient.kt +252 -252
  4. package/esm/src/ast/references/jackson.d.ts +1 -0
  5. package/esm/src/ast/references/jackson.d.ts.map +1 -1
  6. package/esm/src/ast/references/jackson.js +1 -0
  7. package/esm/src/generators/models/args.d.ts +4 -0
  8. package/esm/src/generators/models/args.d.ts.map +1 -1
  9. package/esm/src/generators/models/model-generator.d.ts +1 -0
  10. package/esm/src/generators/models/model-generator.d.ts.map +1 -1
  11. package/esm/src/generators/models/model-generator.js +13 -3
  12. package/esm/src/generators/services/okhttp3-clients/okhttp3-client-generator.js +28 -28
  13. package/esm/src/generators/services/spring-controllers/spring-controller-generator.js +9 -9
  14. package/package.json +2 -2
  15. package/script/src/ast/references/jackson.d.ts +1 -0
  16. package/script/src/ast/references/jackson.d.ts.map +1 -1
  17. package/script/src/ast/references/jackson.js +2 -1
  18. package/script/src/generators/models/args.d.ts +4 -0
  19. package/script/src/generators/models/args.d.ts.map +1 -1
  20. package/script/src/generators/models/model-generator.d.ts +1 -0
  21. package/script/src/generators/models/model-generator.d.ts.map +1 -1
  22. package/script/src/generators/models/model-generator.js +12 -2
  23. package/script/src/generators/services/okhttp3-clients/okhttp3-client-generator.js +28 -28
  24. package/script/src/generators/services/spring-controllers/spring-controller-generator.js +9 -9
  25. package/esm/_dnt.test_polyfills.d.ts +0 -29
  26. package/esm/_dnt.test_polyfills.d.ts.map +0 -1
  27. package/esm/_dnt.test_polyfills.js +0 -31
  28. package/esm/_dnt.test_shims.d.ts +0 -6
  29. package/esm/_dnt.test_shims.d.ts.map +0 -1
  30. package/esm/_dnt.test_shims.js +0 -61
  31. package/esm/deps/jsr.io/@std/assert/1.0.13/assertion_error.d.ts +0 -26
  32. package/esm/deps/jsr.io/@std/assert/1.0.13/assertion_error.d.ts.map +0 -1
  33. package/esm/deps/jsr.io/@std/assert/1.0.13/assertion_error.js +0 -30
  34. package/esm/deps/jsr.io/@std/assert/1.0.13/equal.d.ts +0 -17
  35. package/esm/deps/jsr.io/@std/assert/1.0.13/equal.d.ts.map +0 -1
  36. package/esm/deps/jsr.io/@std/assert/1.0.13/equal.js +0 -183
  37. package/esm/deps/jsr.io/@std/assert/1.0.13/equals.d.ts +0 -35
  38. package/esm/deps/jsr.io/@std/assert/1.0.13/equals.d.ts.map +0 -1
  39. package/esm/deps/jsr.io/@std/assert/1.0.13/equals.js +0 -58
  40. package/esm/deps/jsr.io/@std/assert/1.0.13/false.d.ts +0 -18
  41. package/esm/deps/jsr.io/@std/assert/1.0.13/false.d.ts.map +0 -1
  42. package/esm/deps/jsr.io/@std/assert/1.0.13/false.js +0 -22
  43. package/esm/deps/jsr.io/@std/assert/1.0.13/instance_of.d.ts +0 -23
  44. package/esm/deps/jsr.io/@std/assert/1.0.13/instance_of.d.ts.map +0 -1
  45. package/esm/deps/jsr.io/@std/assert/1.0.13/instance_of.js +0 -53
  46. package/esm/deps/jsr.io/@std/assert/1.0.13/is_error.d.ts +0 -25
  47. package/esm/deps/jsr.io/@std/assert/1.0.13/is_error.d.ts.map +0 -1
  48. package/esm/deps/jsr.io/@std/assert/1.0.13/is_error.js +0 -54
  49. package/esm/deps/jsr.io/@std/assert/1.0.13/match.d.ts +0 -18
  50. package/esm/deps/jsr.io/@std/assert/1.0.13/match.d.ts.map +0 -1
  51. package/esm/deps/jsr.io/@std/assert/1.0.13/match.js +0 -26
  52. package/esm/deps/jsr.io/@std/assert/1.0.13/not_instance_of.d.ts +0 -20
  53. package/esm/deps/jsr.io/@std/assert/1.0.13/not_instance_of.d.ts.map +0 -1
  54. package/esm/deps/jsr.io/@std/assert/1.0.13/not_instance_of.js +0 -29
  55. package/esm/deps/jsr.io/@std/assert/1.0.13/not_match.d.ts +0 -18
  56. package/esm/deps/jsr.io/@std/assert/1.0.13/not_match.d.ts.map +0 -1
  57. package/esm/deps/jsr.io/@std/assert/1.0.13/not_match.js +0 -26
  58. package/esm/deps/jsr.io/@std/assert/1.0.13/not_strict_equals.d.ts +0 -23
  59. package/esm/deps/jsr.io/@std/assert/1.0.13/not_strict_equals.d.ts.map +0 -1
  60. package/esm/deps/jsr.io/@std/assert/1.0.13/not_strict_equals.js +0 -32
  61. package/esm/deps/jsr.io/@std/assert/1.0.13/rejects.d.ts +0 -42
  62. package/esm/deps/jsr.io/@std/assert/1.0.13/rejects.d.ts.map +0 -1
  63. package/esm/deps/jsr.io/@std/assert/1.0.13/rejects.js +0 -53
  64. package/esm/deps/jsr.io/@std/assert/1.0.13/strict_equals.d.ts +0 -24
  65. package/esm/deps/jsr.io/@std/assert/1.0.13/strict_equals.d.ts.map +0 -1
  66. package/esm/deps/jsr.io/@std/assert/1.0.13/strict_equals.js +0 -57
  67. package/esm/deps/jsr.io/@std/expect/1.0.15/_assert_equals.d.ts +0 -20
  68. package/esm/deps/jsr.io/@std/expect/1.0.15/_assert_equals.d.ts.map +0 -1
  69. package/esm/deps/jsr.io/@std/expect/1.0.15/_assert_equals.js +0 -29
  70. package/esm/deps/jsr.io/@std/expect/1.0.15/_assert_is_error.d.ts +0 -14
  71. package/esm/deps/jsr.io/@std/expect/1.0.15/_assert_is_error.d.ts.map +0 -1
  72. package/esm/deps/jsr.io/@std/expect/1.0.15/_assert_is_error.js +0 -43
  73. package/esm/deps/jsr.io/@std/expect/1.0.15/_assert_not_equals.d.ts +0 -17
  74. package/esm/deps/jsr.io/@std/expect/1.0.15/_assert_not_equals.d.ts.map +0 -1
  75. package/esm/deps/jsr.io/@std/expect/1.0.15/_assert_not_equals.js +0 -26
  76. package/esm/deps/jsr.io/@std/expect/1.0.15/_assertions.d.ts +0 -4
  77. package/esm/deps/jsr.io/@std/expect/1.0.15/_assertions.d.ts.map +0 -1
  78. package/esm/deps/jsr.io/@std/expect/1.0.15/_assertions.js +0 -13
  79. package/esm/deps/jsr.io/@std/expect/1.0.15/_asymmetric_matchers.d.ts +0 -46
  80. package/esm/deps/jsr.io/@std/expect/1.0.15/_asymmetric_matchers.d.ts.map +0 -1
  81. package/esm/deps/jsr.io/@std/expect/1.0.15/_asymmetric_matchers.js +0 -161
  82. package/esm/deps/jsr.io/@std/expect/1.0.15/_build_message.d.ts +0 -6
  83. package/esm/deps/jsr.io/@std/expect/1.0.15/_build_message.d.ts.map +0 -1
  84. package/esm/deps/jsr.io/@std/expect/1.0.15/_build_message.js +0 -29
  85. package/esm/deps/jsr.io/@std/expect/1.0.15/_custom_equality_tester.d.ts +0 -4
  86. package/esm/deps/jsr.io/@std/expect/1.0.15/_custom_equality_tester.d.ts.map +0 -1
  87. package/esm/deps/jsr.io/@std/expect/1.0.15/_custom_equality_tester.js +0 -11
  88. package/esm/deps/jsr.io/@std/expect/1.0.15/_equal.d.ts +0 -9
  89. package/esm/deps/jsr.io/@std/expect/1.0.15/_equal.d.ts.map +0 -1
  90. package/esm/deps/jsr.io/@std/expect/1.0.15/_equal.js +0 -191
  91. package/esm/deps/jsr.io/@std/expect/1.0.15/_extend.d.ts +0 -4
  92. package/esm/deps/jsr.io/@std/expect/1.0.15/_extend.d.ts.map +0 -1
  93. package/esm/deps/jsr.io/@std/expect/1.0.15/_extend.js +0 -11
  94. package/esm/deps/jsr.io/@std/expect/1.0.15/_inspect_args.d.ts +0 -3
  95. package/esm/deps/jsr.io/@std/expect/1.0.15/_inspect_args.d.ts.map +0 -1
  96. package/esm/deps/jsr.io/@std/expect/1.0.15/_inspect_args.js +0 -12
  97. package/esm/deps/jsr.io/@std/expect/1.0.15/_matchers.d.ts +0 -34
  98. package/esm/deps/jsr.io/@std/expect/1.0.15/_matchers.d.ts.map +0 -1
  99. package/esm/deps/jsr.io/@std/expect/1.0.15/_matchers.js +0 -713
  100. package/esm/deps/jsr.io/@std/expect/1.0.15/_mock_util.d.ts +0 -11
  101. package/esm/deps/jsr.io/@std/expect/1.0.15/_mock_util.d.ts.map +0 -1
  102. package/esm/deps/jsr.io/@std/expect/1.0.15/_mock_util.js +0 -10
  103. package/esm/deps/jsr.io/@std/expect/1.0.15/_serializer.d.ts +0 -4
  104. package/esm/deps/jsr.io/@std/expect/1.0.15/_serializer.d.ts.map +0 -1
  105. package/esm/deps/jsr.io/@std/expect/1.0.15/_serializer.js +0 -10
  106. package/esm/deps/jsr.io/@std/expect/1.0.15/_types.d.ts +0 -843
  107. package/esm/deps/jsr.io/@std/expect/1.0.15/_types.d.ts.map +0 -1
  108. package/esm/deps/jsr.io/@std/expect/1.0.15/_types.js +0 -3
  109. package/esm/deps/jsr.io/@std/expect/1.0.15/_utils.d.ts +0 -9
  110. package/esm/deps/jsr.io/@std/expect/1.0.15/_utils.d.ts.map +0 -1
  111. package/esm/deps/jsr.io/@std/expect/1.0.15/_utils.js +0 -218
  112. package/esm/deps/jsr.io/@std/expect/1.0.15/expect.d.ts +0 -60
  113. package/esm/deps/jsr.io/@std/expect/1.0.15/expect.d.ts.map +0 -1
  114. package/esm/deps/jsr.io/@std/expect/1.0.15/expect.js +0 -523
  115. package/esm/deps/jsr.io/@std/internal/1.0.6/assertion_state.d.ts +0 -160
  116. package/esm/deps/jsr.io/@std/internal/1.0.6/assertion_state.d.ts.map +0 -1
  117. package/esm/deps/jsr.io/@std/internal/1.0.6/assertion_state.js +0 -200
  118. package/esm/deps/jsr.io/@std/internal/1.0.6/build_message.d.ts +0 -82
  119. package/esm/deps/jsr.io/@std/internal/1.0.6/build_message.d.ts.map +0 -1
  120. package/esm/deps/jsr.io/@std/internal/1.0.6/build_message.js +0 -111
  121. package/esm/deps/jsr.io/@std/internal/1.0.6/diff.d.ts +0 -140
  122. package/esm/deps/jsr.io/@std/internal/1.0.6/diff.d.ts.map +0 -1
  123. package/esm/deps/jsr.io/@std/internal/1.0.6/diff.js +0 -277
  124. package/esm/deps/jsr.io/@std/internal/1.0.6/diff_str.d.ts +0 -99
  125. package/esm/deps/jsr.io/@std/internal/1.0.6/diff_str.d.ts.map +0 -1
  126. package/esm/deps/jsr.io/@std/internal/1.0.6/diff_str.js +0 -183
  127. package/esm/deps/jsr.io/@std/internal/1.0.6/format.d.ts +0 -2
  128. package/esm/deps/jsr.io/@std/internal/1.0.6/format.d.ts.map +0 -1
  129. package/esm/deps/jsr.io/@std/internal/1.0.6/format.js +0 -37
  130. package/esm/deps/jsr.io/@std/internal/1.0.6/styles.d.ts +0 -159
  131. package/esm/deps/jsr.io/@std/internal/1.0.6/styles.d.ts.map +0 -1
  132. package/esm/deps/jsr.io/@std/internal/1.0.6/styles.js +0 -207
  133. package/esm/deps/jsr.io/@std/internal/1.0.6/types.d.ts +0 -16
  134. package/esm/deps/jsr.io/@std/internal/1.0.6/types.d.ts.map +0 -1
  135. package/esm/deps/jsr.io/@std/internal/1.0.6/types.js +0 -3
  136. package/esm/deps/jsr.io/@std/testing/1.0.11/_mock_utils.d.ts +0 -15
  137. package/esm/deps/jsr.io/@std/testing/1.0.11/_mock_utils.d.ts.map +0 -1
  138. package/esm/deps/jsr.io/@std/testing/1.0.11/_mock_utils.js +0 -35
  139. package/esm/deps/jsr.io/@std/testing/1.0.11/_test_suite.d.ts +0 -79
  140. package/esm/deps/jsr.io/@std/testing/1.0.11/_test_suite.d.ts.map +0 -1
  141. package/esm/deps/jsr.io/@std/testing/1.0.11/_test_suite.js +0 -380
  142. package/esm/deps/jsr.io/@std/testing/1.0.11/bdd.d.ts +0 -738
  143. package/esm/deps/jsr.io/@std/testing/1.0.11/bdd.d.ts.map +0 -1
  144. package/esm/deps/jsr.io/@std/testing/1.0.11/bdd.js +0 -654
  145. package/esm/deps/jsr.io/@std/testing/1.0.11/mock.d.ts +0 -674
  146. package/esm/deps/jsr.io/@std/testing/1.0.11/mock.d.ts.map +0 -1
  147. package/esm/deps/jsr.io/@std/testing/1.0.11/mock.js +0 -1083
  148. package/esm/src/ast/nodes/annotation.test.d.ts +0 -2
  149. package/esm/src/ast/nodes/annotation.test.d.ts.map +0 -1
  150. package/esm/src/ast/nodes/annotation.test.js +0 -56
  151. package/esm/src/ast/nodes/argument.test.d.ts +0 -2
  152. package/esm/src/ast/nodes/argument.test.d.ts.map +0 -1
  153. package/esm/src/ast/nodes/argument.test.js +0 -33
  154. package/esm/src/ast/nodes/call.test.d.ts +0 -2
  155. package/esm/src/ast/nodes/call.test.d.ts.map +0 -1
  156. package/esm/src/ast/nodes/call.test.js +0 -35
  157. package/esm/src/ast/nodes/class.test.d.ts +0 -2
  158. package/esm/src/ast/nodes/class.test.d.ts.map +0 -1
  159. package/esm/src/ast/nodes/class.test.js +0 -219
  160. package/esm/src/ast/nodes/constructor.test.d.ts +0 -2
  161. package/esm/src/ast/nodes/constructor.test.d.ts.map +0 -1
  162. package/esm/src/ast/nodes/constructor.test.js +0 -139
  163. package/esm/src/ast/nodes/doc-tag.test.d.ts +0 -2
  164. package/esm/src/ast/nodes/doc-tag.test.d.ts.map +0 -1
  165. package/esm/src/ast/nodes/doc-tag.test.js +0 -67
  166. package/esm/src/ast/nodes/doc.test.d.ts +0 -2
  167. package/esm/src/ast/nodes/doc.test.d.ts.map +0 -1
  168. package/esm/src/ast/nodes/doc.test.js +0 -33
  169. package/esm/src/ast/nodes/enum-value.test.d.ts +0 -2
  170. package/esm/src/ast/nodes/enum-value.test.d.ts.map +0 -1
  171. package/esm/src/ast/nodes/enum-value.test.js +0 -115
  172. package/esm/src/ast/nodes/enum.test.d.ts +0 -2
  173. package/esm/src/ast/nodes/enum.test.d.ts.map +0 -1
  174. package/esm/src/ast/nodes/enum.test.js +0 -129
  175. package/esm/src/ast/nodes/function.test.d.ts +0 -2
  176. package/esm/src/ast/nodes/function.test.d.ts.map +0 -1
  177. package/esm/src/ast/nodes/function.test.js +0 -160
  178. package/esm/src/ast/nodes/generic-parameter.test.d.ts +0 -2
  179. package/esm/src/ast/nodes/generic-parameter.test.d.ts.map +0 -1
  180. package/esm/src/ast/nodes/generic-parameter.test.js +0 -49
  181. package/esm/src/ast/nodes/init-block.test.d.ts +0 -2
  182. package/esm/src/ast/nodes/init-block.test.d.ts.map +0 -1
  183. package/esm/src/ast/nodes/init-block.test.js +0 -28
  184. package/esm/src/ast/nodes/interface.test.d.ts +0 -2
  185. package/esm/src/ast/nodes/interface.test.d.ts.map +0 -1
  186. package/esm/src/ast/nodes/interface.test.js +0 -121
  187. package/esm/src/ast/nodes/object.test.d.ts +0 -2
  188. package/esm/src/ast/nodes/object.test.d.ts.map +0 -1
  189. package/esm/src/ast/nodes/object.test.js +0 -78
  190. package/esm/src/ast/nodes/parameter.test.d.ts +0 -2
  191. package/esm/src/ast/nodes/parameter.test.d.ts.map +0 -1
  192. package/esm/src/ast/nodes/parameter.test.js +0 -152
  193. package/esm/src/ast/nodes/property.test.d.ts +0 -2
  194. package/esm/src/ast/nodes/property.test.d.ts.map +0 -1
  195. package/esm/src/ast/nodes/property.test.js +0 -206
  196. package/esm/src/ast/nodes/reference.test.d.ts +0 -2
  197. package/esm/src/ast/nodes/reference.test.d.ts.map +0 -1
  198. package/esm/src/ast/nodes/reference.test.js +0 -36
  199. package/esm/src/ast/nodes/string.test.d.ts +0 -2
  200. package/esm/src/ast/nodes/string.test.d.ts.map +0 -1
  201. package/esm/src/ast/nodes/string.test.js +0 -48
  202. package/esm/src/import-collection.test.d.ts +0 -2
  203. package/esm/src/import-collection.test.d.ts.map +0 -1
  204. package/esm/src/import-collection.test.js +0 -99
  205. package/esm/tests/openapi-models.test.d.ts +0 -2
  206. package/esm/tests/openapi-models.test.d.ts.map +0 -1
  207. package/esm/tests/openapi-models.test.js +0 -45
  208. package/script/_dnt.test_polyfills.d.ts +0 -29
  209. package/script/_dnt.test_polyfills.d.ts.map +0 -1
  210. package/script/_dnt.test_polyfills.js +0 -32
  211. package/script/_dnt.test_shims.d.ts +0 -6
  212. package/script/_dnt.test_shims.d.ts.map +0 -1
  213. package/script/_dnt.test_shims.js +0 -65
  214. package/script/deps/jsr.io/@std/assert/1.0.13/assertion_error.d.ts +0 -26
  215. package/script/deps/jsr.io/@std/assert/1.0.13/assertion_error.d.ts.map +0 -1
  216. package/script/deps/jsr.io/@std/assert/1.0.13/assertion_error.js +0 -34
  217. package/script/deps/jsr.io/@std/assert/1.0.13/equal.d.ts +0 -17
  218. package/script/deps/jsr.io/@std/assert/1.0.13/equal.d.ts.map +0 -1
  219. package/script/deps/jsr.io/@std/assert/1.0.13/equal.js +0 -187
  220. package/script/deps/jsr.io/@std/assert/1.0.13/equals.d.ts +0 -35
  221. package/script/deps/jsr.io/@std/assert/1.0.13/equals.d.ts.map +0 -1
  222. package/script/deps/jsr.io/@std/assert/1.0.13/equals.js +0 -61
  223. package/script/deps/jsr.io/@std/assert/1.0.13/false.d.ts +0 -18
  224. package/script/deps/jsr.io/@std/assert/1.0.13/false.d.ts.map +0 -1
  225. package/script/deps/jsr.io/@std/assert/1.0.13/false.js +0 -25
  226. package/script/deps/jsr.io/@std/assert/1.0.13/instance_of.d.ts +0 -23
  227. package/script/deps/jsr.io/@std/assert/1.0.13/instance_of.d.ts.map +0 -1
  228. package/script/deps/jsr.io/@std/assert/1.0.13/instance_of.js +0 -56
  229. package/script/deps/jsr.io/@std/assert/1.0.13/is_error.d.ts +0 -25
  230. package/script/deps/jsr.io/@std/assert/1.0.13/is_error.d.ts.map +0 -1
  231. package/script/deps/jsr.io/@std/assert/1.0.13/is_error.js +0 -57
  232. package/script/deps/jsr.io/@std/assert/1.0.13/match.d.ts +0 -18
  233. package/script/deps/jsr.io/@std/assert/1.0.13/match.d.ts.map +0 -1
  234. package/script/deps/jsr.io/@std/assert/1.0.13/match.js +0 -29
  235. package/script/deps/jsr.io/@std/assert/1.0.13/not_instance_of.d.ts +0 -20
  236. package/script/deps/jsr.io/@std/assert/1.0.13/not_instance_of.d.ts.map +0 -1
  237. package/script/deps/jsr.io/@std/assert/1.0.13/not_instance_of.js +0 -32
  238. package/script/deps/jsr.io/@std/assert/1.0.13/not_match.d.ts +0 -18
  239. package/script/deps/jsr.io/@std/assert/1.0.13/not_match.d.ts.map +0 -1
  240. package/script/deps/jsr.io/@std/assert/1.0.13/not_match.js +0 -29
  241. package/script/deps/jsr.io/@std/assert/1.0.13/not_strict_equals.d.ts +0 -23
  242. package/script/deps/jsr.io/@std/assert/1.0.13/not_strict_equals.d.ts.map +0 -1
  243. package/script/deps/jsr.io/@std/assert/1.0.13/not_strict_equals.js +0 -35
  244. package/script/deps/jsr.io/@std/assert/1.0.13/rejects.d.ts +0 -42
  245. package/script/deps/jsr.io/@std/assert/1.0.13/rejects.d.ts.map +0 -1
  246. package/script/deps/jsr.io/@std/assert/1.0.13/rejects.js +0 -56
  247. package/script/deps/jsr.io/@std/assert/1.0.13/strict_equals.d.ts +0 -24
  248. package/script/deps/jsr.io/@std/assert/1.0.13/strict_equals.d.ts.map +0 -1
  249. package/script/deps/jsr.io/@std/assert/1.0.13/strict_equals.js +0 -60
  250. package/script/deps/jsr.io/@std/expect/1.0.15/_assert_equals.d.ts +0 -20
  251. package/script/deps/jsr.io/@std/expect/1.0.15/_assert_equals.d.ts.map +0 -1
  252. package/script/deps/jsr.io/@std/expect/1.0.15/_assert_equals.js +0 -32
  253. package/script/deps/jsr.io/@std/expect/1.0.15/_assert_is_error.d.ts +0 -14
  254. package/script/deps/jsr.io/@std/expect/1.0.15/_assert_is_error.d.ts.map +0 -1
  255. package/script/deps/jsr.io/@std/expect/1.0.15/_assert_is_error.js +0 -46
  256. package/script/deps/jsr.io/@std/expect/1.0.15/_assert_not_equals.d.ts +0 -17
  257. package/script/deps/jsr.io/@std/expect/1.0.15/_assert_not_equals.d.ts.map +0 -1
  258. package/script/deps/jsr.io/@std/expect/1.0.15/_assert_not_equals.js +0 -29
  259. package/script/deps/jsr.io/@std/expect/1.0.15/_assertions.d.ts +0 -4
  260. package/script/deps/jsr.io/@std/expect/1.0.15/_assertions.d.ts.map +0 -1
  261. package/script/deps/jsr.io/@std/expect/1.0.15/_assertions.js +0 -18
  262. package/script/deps/jsr.io/@std/expect/1.0.15/_asymmetric_matchers.d.ts +0 -46
  263. package/script/deps/jsr.io/@std/expect/1.0.15/_asymmetric_matchers.d.ts.map +0 -1
  264. package/script/deps/jsr.io/@std/expect/1.0.15/_asymmetric_matchers.js +0 -183
  265. package/script/deps/jsr.io/@std/expect/1.0.15/_build_message.d.ts +0 -6
  266. package/script/deps/jsr.io/@std/expect/1.0.15/_build_message.d.ts.map +0 -1
  267. package/script/deps/jsr.io/@std/expect/1.0.15/_build_message.js +0 -33
  268. package/script/deps/jsr.io/@std/expect/1.0.15/_custom_equality_tester.d.ts +0 -4
  269. package/script/deps/jsr.io/@std/expect/1.0.15/_custom_equality_tester.d.ts.map +0 -1
  270. package/script/deps/jsr.io/@std/expect/1.0.15/_custom_equality_tester.js +0 -15
  271. package/script/deps/jsr.io/@std/expect/1.0.15/_equal.d.ts +0 -9
  272. package/script/deps/jsr.io/@std/expect/1.0.15/_equal.d.ts.map +0 -1
  273. package/script/deps/jsr.io/@std/expect/1.0.15/_equal.js +0 -194
  274. package/script/deps/jsr.io/@std/expect/1.0.15/_extend.d.ts +0 -4
  275. package/script/deps/jsr.io/@std/expect/1.0.15/_extend.d.ts.map +0 -1
  276. package/script/deps/jsr.io/@std/expect/1.0.15/_extend.js +0 -15
  277. package/script/deps/jsr.io/@std/expect/1.0.15/_inspect_args.d.ts +0 -3
  278. package/script/deps/jsr.io/@std/expect/1.0.15/_inspect_args.d.ts.map +0 -1
  279. package/script/deps/jsr.io/@std/expect/1.0.15/_inspect_args.js +0 -17
  280. package/script/deps/jsr.io/@std/expect/1.0.15/_matchers.d.ts +0 -34
  281. package/script/deps/jsr.io/@std/expect/1.0.15/_matchers.d.ts.map +0 -1
  282. package/script/deps/jsr.io/@std/expect/1.0.15/_matchers.js +0 -747
  283. package/script/deps/jsr.io/@std/expect/1.0.15/_mock_util.d.ts +0 -11
  284. package/script/deps/jsr.io/@std/expect/1.0.15/_mock_util.d.ts.map +0 -1
  285. package/script/deps/jsr.io/@std/expect/1.0.15/_mock_util.js +0 -14
  286. package/script/deps/jsr.io/@std/expect/1.0.15/_serializer.d.ts +0 -4
  287. package/script/deps/jsr.io/@std/expect/1.0.15/_serializer.d.ts.map +0 -1
  288. package/script/deps/jsr.io/@std/expect/1.0.15/_serializer.js +0 -14
  289. package/script/deps/jsr.io/@std/expect/1.0.15/_types.d.ts +0 -843
  290. package/script/deps/jsr.io/@std/expect/1.0.15/_types.d.ts.map +0 -1
  291. package/script/deps/jsr.io/@std/expect/1.0.15/_types.js +0 -4
  292. package/script/deps/jsr.io/@std/expect/1.0.15/_utils.d.ts +0 -9
  293. package/script/deps/jsr.io/@std/expect/1.0.15/_utils.d.ts.map +0 -1
  294. package/script/deps/jsr.io/@std/expect/1.0.15/_utils.js +0 -226
  295. package/script/deps/jsr.io/@std/expect/1.0.15/expect.d.ts +0 -60
  296. package/script/deps/jsr.io/@std/expect/1.0.15/expect.d.ts.map +0 -1
  297. package/script/deps/jsr.io/@std/expect/1.0.15/expect.js +0 -527
  298. package/script/deps/jsr.io/@std/internal/1.0.6/assertion_state.d.ts +0 -160
  299. package/script/deps/jsr.io/@std/internal/1.0.6/assertion_state.d.ts.map +0 -1
  300. package/script/deps/jsr.io/@std/internal/1.0.6/assertion_state.js +0 -205
  301. package/script/deps/jsr.io/@std/internal/1.0.6/build_message.d.ts +0 -82
  302. package/script/deps/jsr.io/@std/internal/1.0.6/build_message.d.ts.map +0 -1
  303. package/script/deps/jsr.io/@std/internal/1.0.6/build_message.js +0 -116
  304. package/script/deps/jsr.io/@std/internal/1.0.6/diff.d.ts +0 -140
  305. package/script/deps/jsr.io/@std/internal/1.0.6/diff.d.ts.map +0 -1
  306. package/script/deps/jsr.io/@std/internal/1.0.6/diff.js +0 -284
  307. package/script/deps/jsr.io/@std/internal/1.0.6/diff_str.d.ts +0 -99
  308. package/script/deps/jsr.io/@std/internal/1.0.6/diff_str.d.ts.map +0 -1
  309. package/script/deps/jsr.io/@std/internal/1.0.6/diff_str.js +0 -189
  310. package/script/deps/jsr.io/@std/internal/1.0.6/format.d.ts +0 -2
  311. package/script/deps/jsr.io/@std/internal/1.0.6/format.d.ts.map +0 -1
  312. package/script/deps/jsr.io/@std/internal/1.0.6/format.js +0 -41
  313. package/script/deps/jsr.io/@std/internal/1.0.6/styles.d.ts +0 -159
  314. package/script/deps/jsr.io/@std/internal/1.0.6/styles.d.ts.map +0 -1
  315. package/script/deps/jsr.io/@std/internal/1.0.6/styles.js +0 -220
  316. package/script/deps/jsr.io/@std/internal/1.0.6/types.d.ts +0 -16
  317. package/script/deps/jsr.io/@std/internal/1.0.6/types.d.ts.map +0 -1
  318. package/script/deps/jsr.io/@std/internal/1.0.6/types.js +0 -4
  319. package/script/deps/jsr.io/@std/testing/1.0.11/_mock_utils.d.ts +0 -15
  320. package/script/deps/jsr.io/@std/testing/1.0.11/_mock_utils.d.ts.map +0 -1
  321. package/script/deps/jsr.io/@std/testing/1.0.11/_mock_utils.js +0 -41
  322. package/script/deps/jsr.io/@std/testing/1.0.11/_test_suite.d.ts +0 -79
  323. package/script/deps/jsr.io/@std/testing/1.0.11/_test_suite.d.ts.map +0 -1
  324. package/script/deps/jsr.io/@std/testing/1.0.11/_test_suite.js +0 -385
  325. package/script/deps/jsr.io/@std/testing/1.0.11/bdd.d.ts +0 -738
  326. package/script/deps/jsr.io/@std/testing/1.0.11/bdd.d.ts.map +0 -1
  327. package/script/deps/jsr.io/@std/testing/1.0.11/bdd.js +0 -665
  328. package/script/deps/jsr.io/@std/testing/1.0.11/mock.d.ts +0 -674
  329. package/script/deps/jsr.io/@std/testing/1.0.11/mock.d.ts.map +0 -1
  330. package/script/deps/jsr.io/@std/testing/1.0.11/mock.js +0 -1102
  331. package/script/src/ast/nodes/annotation.test.d.ts +0 -2
  332. package/script/src/ast/nodes/annotation.test.d.ts.map +0 -1
  333. package/script/src/ast/nodes/annotation.test.js +0 -58
  334. package/script/src/ast/nodes/argument.test.d.ts +0 -2
  335. package/script/src/ast/nodes/argument.test.d.ts.map +0 -1
  336. package/script/src/ast/nodes/argument.test.js +0 -35
  337. package/script/src/ast/nodes/call.test.d.ts +0 -2
  338. package/script/src/ast/nodes/call.test.d.ts.map +0 -1
  339. package/script/src/ast/nodes/call.test.js +0 -37
  340. package/script/src/ast/nodes/class.test.d.ts +0 -2
  341. package/script/src/ast/nodes/class.test.d.ts.map +0 -1
  342. package/script/src/ast/nodes/class.test.js +0 -221
  343. package/script/src/ast/nodes/constructor.test.d.ts +0 -2
  344. package/script/src/ast/nodes/constructor.test.d.ts.map +0 -1
  345. package/script/src/ast/nodes/constructor.test.js +0 -141
  346. package/script/src/ast/nodes/doc-tag.test.d.ts +0 -2
  347. package/script/src/ast/nodes/doc-tag.test.d.ts.map +0 -1
  348. package/script/src/ast/nodes/doc-tag.test.js +0 -69
  349. package/script/src/ast/nodes/doc.test.d.ts +0 -2
  350. package/script/src/ast/nodes/doc.test.d.ts.map +0 -1
  351. package/script/src/ast/nodes/doc.test.js +0 -35
  352. package/script/src/ast/nodes/enum-value.test.d.ts +0 -2
  353. package/script/src/ast/nodes/enum-value.test.d.ts.map +0 -1
  354. package/script/src/ast/nodes/enum-value.test.js +0 -117
  355. package/script/src/ast/nodes/enum.test.d.ts +0 -2
  356. package/script/src/ast/nodes/enum.test.d.ts.map +0 -1
  357. package/script/src/ast/nodes/enum.test.js +0 -131
  358. package/script/src/ast/nodes/function.test.d.ts +0 -2
  359. package/script/src/ast/nodes/function.test.d.ts.map +0 -1
  360. package/script/src/ast/nodes/function.test.js +0 -162
  361. package/script/src/ast/nodes/generic-parameter.test.d.ts +0 -2
  362. package/script/src/ast/nodes/generic-parameter.test.d.ts.map +0 -1
  363. package/script/src/ast/nodes/generic-parameter.test.js +0 -51
  364. package/script/src/ast/nodes/init-block.test.d.ts +0 -2
  365. package/script/src/ast/nodes/init-block.test.d.ts.map +0 -1
  366. package/script/src/ast/nodes/init-block.test.js +0 -30
  367. package/script/src/ast/nodes/interface.test.d.ts +0 -2
  368. package/script/src/ast/nodes/interface.test.d.ts.map +0 -1
  369. package/script/src/ast/nodes/interface.test.js +0 -123
  370. package/script/src/ast/nodes/object.test.d.ts +0 -2
  371. package/script/src/ast/nodes/object.test.d.ts.map +0 -1
  372. package/script/src/ast/nodes/object.test.js +0 -80
  373. package/script/src/ast/nodes/parameter.test.d.ts +0 -2
  374. package/script/src/ast/nodes/parameter.test.d.ts.map +0 -1
  375. package/script/src/ast/nodes/parameter.test.js +0 -154
  376. package/script/src/ast/nodes/property.test.d.ts +0 -2
  377. package/script/src/ast/nodes/property.test.d.ts.map +0 -1
  378. package/script/src/ast/nodes/property.test.js +0 -208
  379. package/script/src/ast/nodes/reference.test.d.ts +0 -2
  380. package/script/src/ast/nodes/reference.test.d.ts.map +0 -1
  381. package/script/src/ast/nodes/reference.test.js +0 -38
  382. package/script/src/ast/nodes/string.test.d.ts +0 -2
  383. package/script/src/ast/nodes/string.test.d.ts.map +0 -1
  384. package/script/src/ast/nodes/string.test.js +0 -50
  385. package/script/src/import-collection.test.d.ts +0 -2
  386. package/script/src/import-collection.test.d.ts.map +0 -1
  387. package/script/src/import-collection.test.js +0 -101
  388. package/script/tests/openapi-models.test.d.ts +0 -2
  389. package/script/tests/openapi-models.test.d.ts.map +0 -1
  390. package/script/tests/openapi-models.test.js +0 -48
  391. package/src/_dnt.test_polyfills.ts +0 -70
  392. package/src/_dnt.test_shims.ts +0 -64
  393. package/src/deps/jsr.io/@std/assert/1.0.13/assertion_error.ts +0 -31
  394. package/src/deps/jsr.io/@std/assert/1.0.13/equal.ts +0 -210
  395. package/src/deps/jsr.io/@std/assert/1.0.13/equals.ts +0 -65
  396. package/src/deps/jsr.io/@std/assert/1.0.13/false.ts +0 -26
  397. package/src/deps/jsr.io/@std/assert/1.0.13/instance_of.ts +0 -64
  398. package/src/deps/jsr.io/@std/assert/1.0.13/is_error.ts +0 -65
  399. package/src/deps/jsr.io/@std/assert/1.0.13/match.ts +0 -30
  400. package/src/deps/jsr.io/@std/assert/1.0.13/not_instance_of.ts +0 -33
  401. package/src/deps/jsr.io/@std/assert/1.0.13/not_match.ts +0 -30
  402. package/src/deps/jsr.io/@std/assert/1.0.13/not_strict_equals.ts +0 -42
  403. package/src/deps/jsr.io/@std/assert/1.0.13/rejects.ts +0 -123
  404. package/src/deps/jsr.io/@std/assert/1.0.13/strict_equals.ts +0 -67
  405. package/src/deps/jsr.io/@std/expect/1.0.15/_assert_equals.ts +0 -38
  406. package/src/deps/jsr.io/@std/expect/1.0.15/_assert_is_error.ts +0 -54
  407. package/src/deps/jsr.io/@std/expect/1.0.15/_assert_not_equals.ts +0 -35
  408. package/src/deps/jsr.io/@std/expect/1.0.15/_assertions.ts +0 -18
  409. package/src/deps/jsr.io/@std/expect/1.0.15/_asymmetric_matchers.ts +0 -198
  410. package/src/deps/jsr.io/@std/expect/1.0.15/_build_message.ts +0 -51
  411. package/src/deps/jsr.io/@std/expect/1.0.15/_custom_equality_tester.ts +0 -19
  412. package/src/deps/jsr.io/@std/expect/1.0.15/_equal.ts +0 -230
  413. package/src/deps/jsr.io/@std/expect/1.0.15/_extend.ts +0 -16
  414. package/src/deps/jsr.io/@std/expect/1.0.15/_inspect_args.ts +0 -15
  415. package/src/deps/jsr.io/@std/expect/1.0.15/_matchers.ts +0 -1027
  416. package/src/deps/jsr.io/@std/expect/1.0.15/_mock_util.ts +0 -22
  417. package/src/deps/jsr.io/@std/expect/1.0.15/_serializer.ts +0 -15
  418. package/src/deps/jsr.io/@std/expect/1.0.15/_types.ts +0 -923
  419. package/src/deps/jsr.io/@std/expect/1.0.15/_utils.ts +0 -283
  420. package/src/deps/jsr.io/@std/expect/1.0.15/expect.ts +0 -620
  421. package/src/deps/jsr.io/@std/internal/1.0.6/assertion_state.ts +0 -215
  422. package/src/deps/jsr.io/@std/internal/1.0.6/build_message.ts +0 -134
  423. package/src/deps/jsr.io/@std/internal/1.0.6/diff.ts +0 -317
  424. package/src/deps/jsr.io/@std/internal/1.0.6/diff_str.ts +0 -208
  425. package/src/deps/jsr.io/@std/internal/1.0.6/format.ts +0 -39
  426. package/src/deps/jsr.io/@std/internal/1.0.6/styles.ts +0 -233
  427. package/src/deps/jsr.io/@std/internal/1.0.6/types.ts +0 -19
  428. package/src/deps/jsr.io/@std/testing/1.0.11/_mock_utils.ts +0 -43
  429. package/src/deps/jsr.io/@std/testing/1.0.11/_test_suite.ts +0 -448
  430. package/src/deps/jsr.io/@std/testing/1.0.11/bdd.ts +0 -1288
  431. package/src/deps/jsr.io/@std/testing/1.0.11/mock.ts +0 -1807
  432. package/src/mod.ts +0 -8
  433. package/src/src/assets.ts +0 -9
  434. package/src/src/ast/_index.ts +0 -66
  435. package/src/src/ast/common.ts +0 -1
  436. package/src/src/ast/index.ts +0 -1
  437. package/src/src/ast/node.ts +0 -10
  438. package/src/src/ast/nodes/annotation.test.ts +0 -69
  439. package/src/src/ast/nodes/annotation.ts +0 -79
  440. package/src/src/ast/nodes/argument.test.ts +0 -41
  441. package/src/src/ast/nodes/argument.ts +0 -62
  442. package/src/src/ast/nodes/call.test.ts +0 -44
  443. package/src/src/ast/nodes/call.ts +0 -66
  444. package/src/src/ast/nodes/class.test.ts +0 -274
  445. package/src/src/ast/nodes/class.ts +0 -178
  446. package/src/src/ast/nodes/collection-literal.ts +0 -49
  447. package/src/src/ast/nodes/constructor.test.ts +0 -178
  448. package/src/src/ast/nodes/constructor.ts +0 -126
  449. package/src/src/ast/nodes/doc-tag.test.ts +0 -84
  450. package/src/src/ast/nodes/doc-tag.ts +0 -138
  451. package/src/src/ast/nodes/doc.test.ts +0 -42
  452. package/src/src/ast/nodes/doc.ts +0 -111
  453. package/src/src/ast/nodes/enum-value.test.ts +0 -146
  454. package/src/src/ast/nodes/enum-value.ts +0 -100
  455. package/src/src/ast/nodes/enum.test.ts +0 -167
  456. package/src/src/ast/nodes/enum.ts +0 -163
  457. package/src/src/ast/nodes/function.test.ts +0 -194
  458. package/src/src/ast/nodes/function.ts +0 -178
  459. package/src/src/ast/nodes/generic-parameter.test.ts +0 -60
  460. package/src/src/ast/nodes/generic-parameter.ts +0 -54
  461. package/src/src/ast/nodes/init-block.test.ts +0 -36
  462. package/src/src/ast/nodes/init-block.ts +0 -38
  463. package/src/src/ast/nodes/interface.test.ts +0 -151
  464. package/src/src/ast/nodes/interface.ts +0 -133
  465. package/src/src/ast/nodes/lambda-type.ts +0 -68
  466. package/src/src/ast/nodes/lambda.ts +0 -68
  467. package/src/src/ast/nodes/object.test.ts +0 -101
  468. package/src/src/ast/nodes/object.ts +0 -102
  469. package/src/src/ast/nodes/parameter.test.ts +0 -191
  470. package/src/src/ast/nodes/parameter.ts +0 -118
  471. package/src/src/ast/nodes/property.test.ts +0 -253
  472. package/src/src/ast/nodes/property.ts +0 -225
  473. package/src/src/ast/nodes/reference.test.ts +0 -47
  474. package/src/src/ast/nodes/reference.ts +0 -178
  475. package/src/src/ast/nodes/string.test.ts +0 -61
  476. package/src/src/ast/nodes/string.ts +0 -114
  477. package/src/src/ast/nodes/types.ts +0 -23
  478. package/src/src/ast/references/index.ts +0 -8
  479. package/src/src/ast/references/jackson.ts +0 -16
  480. package/src/src/ast/references/jakarta.ts +0 -14
  481. package/src/src/ast/references/java.ts +0 -19
  482. package/src/src/ast/references/kotlin.ts +0 -41
  483. package/src/src/ast/references/okhttp3.ts +0 -5
  484. package/src/src/ast/references/reactor.ts +0 -5
  485. package/src/src/ast/references/spring.ts +0 -72
  486. package/src/src/ast/references/swagger.ts +0 -23
  487. package/src/src/ast/utils/get-kotlin-builder-options.ts +0 -19
  488. package/src/src/ast/utils/to-kt-node.ts +0 -31
  489. package/src/src/ast/utils/write-kt-annotations.ts +0 -15
  490. package/src/src/ast/utils/write-kt-arguments.ts +0 -45
  491. package/src/src/ast/utils/write-kt-enum-values.ts +0 -27
  492. package/src/src/ast/utils/write-kt-generic-parameters.ts +0 -12
  493. package/src/src/ast/utils/write-kt-members.ts +0 -25
  494. package/src/src/ast/utils/write-kt-node.ts +0 -37
  495. package/src/src/ast/utils/write-kt-parameters.ts +0 -25
  496. package/src/src/common-results.ts +0 -4
  497. package/src/src/config.ts +0 -41
  498. package/src/src/file-builder.ts +0 -108
  499. package/src/src/generators/file-generator.ts +0 -29
  500. package/src/src/generators/index.ts +0 -4
  501. package/src/src/generators/models/args.ts +0 -123
  502. package/src/src/generators/models/index.ts +0 -4
  503. package/src/src/generators/models/model-generator.ts +0 -653
  504. package/src/src/generators/models/models-generator.ts +0 -65
  505. package/src/src/generators/models/models.ts +0 -95
  506. package/src/src/generators/services/okhttp3-clients/args.ts +0 -83
  507. package/src/src/generators/services/okhttp3-clients/index.ts +0 -4
  508. package/src/src/generators/services/okhttp3-clients/models.ts +0 -62
  509. package/src/src/generators/services/okhttp3-clients/okhttp3-client-generator.ts +0 -583
  510. package/src/src/generators/services/okhttp3-clients/okhttp3-clients-generator.ts +0 -130
  511. package/src/src/generators/services/okhttp3-clients/refs.ts +0 -55
  512. package/src/src/generators/services/spring-controllers/args.ts +0 -93
  513. package/src/src/generators/services/spring-controllers/index.ts +0 -4
  514. package/src/src/generators/services/spring-controllers/models.ts +0 -71
  515. package/src/src/generators/services/spring-controllers/refs.ts +0 -17
  516. package/src/src/generators/services/spring-controllers/spring-controller-generator.ts +0 -814
  517. package/src/src/generators/services/spring-controllers/spring-controllers-generator.ts +0 -118
  518. package/src/src/import-collection.test.ts +0 -116
  519. package/src/src/import-collection.ts +0 -98
  520. package/src/src/types.ts +0 -3
  521. package/src/src/utils.ts +0 -39
  522. package/src/tests/openapi-models.test.ts +0 -63
  523. package/test_runner.js +0 -227
@@ -1,583 +0,0 @@
1
- import { dirname } from 'node:path';
2
-
3
-
4
- import fs from 'fs-extra';
5
-
6
- import {
7
- type ApiParameter,
8
- type ApiSchema,
9
- type AppendValueGroup,
10
- appendValueGroup,
11
- builderTemplate as s,
12
- createOverwriteProxy,
13
- type MaybePromise,
14
- resolveAnyOfAndAllOf,
15
- SourceBuilder,
16
- toCasing,
17
- } from '@goast/core';
18
-
19
- import { kt } from '../../../ast/index.js';
20
- import type { KtValue } from '../../../ast/nodes/types.js';
21
- import type { KotlinImport } from '../../../common-results.js';
22
- import { KotlinFileBuilder } from '../../../file-builder.js';
23
- import type { ApiParameterWithMultipartInfo } from '../../../types.js';
24
- import { modifyString } from '../../../utils.js';
25
- import { KotlinFileGenerator } from '../../file-generator.js';
26
- import type { DefaultKotlinOkHttp3GeneratorArgs as Args } from './index.js';
27
- import type { KotlinOkHttp3ClientGeneratorContext, KotlinOkHttp3ClientGeneratorOutput } from './models.js';
28
-
29
- type Context = KotlinOkHttp3ClientGeneratorContext;
30
- type Output = KotlinOkHttp3ClientGeneratorOutput;
31
- type Builder = KotlinFileBuilder;
32
-
33
- export interface KotlinOkHttp3Generator<TOutput extends Output = Output> {
34
- generate(ctx: Context): MaybePromise<TOutput>;
35
- }
36
-
37
- export class DefaultKotlinOkHttp3Generator extends KotlinFileGenerator<Context, Output>
38
- implements KotlinOkHttp3Generator {
39
- public generate(ctx: KotlinOkHttp3ClientGeneratorContext): MaybePromise<KotlinImport> {
40
- const typeName = this.getApiClientName(ctx, {});
41
- const packageName = this.getPackageName(ctx, {});
42
- const filePath = this.getFilePath(ctx, { packageName });
43
- fs.ensureDirSync(dirname(filePath));
44
-
45
- console.log(`Generating client for service ${ctx.service.name} to ${filePath}...`);
46
-
47
- const builder = new KotlinFileBuilder(packageName, ctx.config);
48
- builder.append(this.getClientFileContent(ctx, {}));
49
-
50
- fs.writeFileSync(filePath, builder.toString());
51
-
52
- return { typeName, packageName };
53
- }
54
-
55
- protected getClientFileContent(ctx: Context, _args: Args.GetClientFileContent): AppendValueGroup<Builder> {
56
- return appendValueGroup([this.getClientClass(ctx, {})]);
57
- }
58
-
59
- protected getClientClass(ctx: Context, _args: Args.GetClientClass): kt.Class<Builder> {
60
- return kt.class(this.getApiClientName(ctx, {}), {
61
- annotations: [
62
- ctx.service.endpoints.length === 0 || ctx.service.endpoints.some((x) => !x.deprecated)
63
- ? null
64
- : kt.annotation(kt.refs.deprecated(), [kt.argument(kt.string(''))]),
65
- ],
66
- extends: ctx.refs.apiClient(),
67
- primaryConstructor: kt.constructor(
68
- [
69
- kt.parameter('basePath', kt.refs.string(), { default: 'defaultBasePath' }),
70
- kt.parameter('client', kt.refs.okhttp3.okHttpClient(), {
71
- default: 'defaultClient',
72
- }),
73
- ],
74
- null,
75
- {
76
- delegateTarget: 'super',
77
- delegateArguments: ['basePath', 'client'],
78
- },
79
- ),
80
- companionObject: this.getClientCompanionObject(ctx, {}),
81
- members: [
82
- ...ctx.service.endpoints.flatMap((endpoint) =>
83
- this.getEndpointClientMembers(ctx, { endpoint, parameters: this.getAllParameters(ctx, { endpoint }) })
84
- ),
85
- ...this.getAdditionalClientMembers(ctx, {}),
86
- ],
87
- });
88
- }
89
-
90
- protected getClientCompanionObject(ctx: Context, _args: Args.GetClientCompanionObject): kt.Object<Builder> {
91
- const result = kt.object<Builder>();
92
-
93
- result.members.push(
94
- kt.property('defaultBasePath', {
95
- annotations: [kt.annotation(kt.refs.jvmStatic())],
96
- type: kt.refs.string(),
97
- delegate: kt.refs.lazyFun.infer(),
98
- delegateArguments: [
99
- kt.lambda(
100
- [],
101
- kt.call(
102
- [kt.call([kt.refs.java.system(), 'getProperties'], []), 'getProperty'],
103
- [kt.call([ctx.refs.apiClient(), 'baseUrlKey']), kt.string(this.getBasePath(ctx, {}))],
104
- ),
105
- ),
106
- ],
107
- }),
108
- );
109
-
110
- return result;
111
- }
112
-
113
- protected getEndpointClientMembers(ctx: Context, args: Args.GetEndpointClientMembers): kt.ClassMember<Builder>[] {
114
- const { endpoint, parameters } = args;
115
- const responseSchema = this.getResponseSchema(ctx, { endpoint });
116
- return [
117
- this.getEndpointClientMethod(ctx, { endpoint, parameters, responseSchema }),
118
- this.getEndpointClientHttpInfoMethod(ctx, { endpoint, parameters, responseSchema }),
119
- this.getEndpointClientRequestConfigMethod(ctx, { endpoint, parameters }),
120
- ];
121
- }
122
-
123
- protected getEndpointClientMethod(ctx: Context, args: Args.GetEndpointClientMethod): kt.Function<Builder> {
124
- const { endpoint, parameters, responseSchema } = args;
125
-
126
- return kt.function(toCasing(endpoint.name, ctx.config.functionNameCasing), {
127
- doc: kt.doc(endpoint.summary, [
128
- kt.docTag('throws', 'IllegalStateException', 'If the request is not correctly configured'),
129
- kt.docTag('throws', 'IOException', 'Rethrows the OkHttp execute method exception'),
130
- kt.docTag(
131
- 'throws',
132
- 'UnsupportedOperationException',
133
- 'If the API returns an informational or redirection response',
134
- ),
135
- kt.docTag('throws', 'ClientException', 'If the API returns a client error response'),
136
- kt.docTag('throws', 'ServerException', 'If the API returns a server error response'),
137
- ]),
138
- annotations: [
139
- kt.annotation(kt.refs.throws(), [
140
- kt.refs.java.illegalStateException({ classReference: true }),
141
- kt.refs.java.ioException({ classReference: true }),
142
- kt.refs.java.unsupportedOperationException({ classReference: true }),
143
- ctx.refs.clientException({ classReference: true }),
144
- ctx.refs.serverException({ classReference: true }),
145
- ]),
146
- endpoint.deprecated ? kt.annotation(kt.refs.deprecated(), [kt.argument(kt.string(''))]) : null,
147
- ],
148
- parameters: parameters.map((p) =>
149
- kt.parameter(
150
- toCasing(p.name, ctx.config.parameterNameCasing),
151
- this.getParameterType(ctx, { endpoint, parameter: p }),
152
- {
153
- description: p.description,
154
- default: !p.required ? kt.toNode(p.schema?.default) : null,
155
- },
156
- )
157
- ),
158
- returnType: this.getTypeUsage(ctx, { schema: responseSchema, fallback: kt.refs.unit() }),
159
- body: this.getEndpointClientMethodBody(ctx, { endpoint, parameters, responseSchema }),
160
- });
161
- }
162
-
163
- protected getEndpointClientMethodBody(
164
- ctx: Context,
165
- args: Args.GetEndpointClientMethodBody,
166
- ): AppendValueGroup<Builder> {
167
- const { endpoint, parameters, responseSchema } = args;
168
-
169
- return appendValueGroup(
170
- [
171
- s`val localVarResponse = ${
172
- kt.call(
173
- [toCasing(endpoint.name + '_WithHttpInfo', ctx.config.functionNameCasing)],
174
- parameters.map((x) => toCasing(x.name, ctx.config.parameterNameCasing)),
175
- )
176
- }`,
177
- '',
178
- s`return when (localVarResponse.responseType) {${s.indent`
179
- ${ctx.refs.responseType()}.Success -> ${
180
- responseSchema === undefined
181
- ? kt.refs.unit()
182
- : s`(localVarResponse as ${ctx.refs.success(['*'])}).data as ${
183
- this.getTypeUsage(ctx, {
184
- schema: responseSchema,
185
- })
186
- }`
187
- }
188
- ${ctx.refs.responseType()}.Informational -> throw ${kt.refs.java.unsupportedOperationException()}("Client does not support Informational responses.")
189
- ${ctx.refs.responseType()}.Redirection -> throw ${kt.refs.java.unsupportedOperationException()}("Client does not support Redirection responses.")
190
- ${ctx.refs.responseType()}.ClientError -> {${s.indent`
191
- val localVarError = localVarResponse as ${ctx.refs.clientError(['*'])}
192
- throw ${ctx.refs.clientException()}(${s.indent`
193
- "Client error : \${localVarError.statusCode} \${localVarError.message.orEmpty()}",
194
- localVarError.statusCode,
195
- localVarResponse`}
196
- )`}
197
- }
198
-
199
- ${ctx.refs.responseType()}.ServerError -> {${s.indent`
200
- val localVarError = localVarResponse as ${ctx.refs.serverError(['*'])}
201
- throw ${ctx.refs.serverException()}(${s.indent`
202
- "Server error : \${localVarError.statusCode} \${localVarError.message.orEmpty()}",
203
- localVarError.statusCode,
204
- localVarResponse`}
205
- )`}
206
- }`}
207
- }`,
208
- ],
209
- '\n',
210
- );
211
- }
212
-
213
- protected getEndpointClientHttpInfoMethod(
214
- ctx: Context,
215
- args: Args.GetEndpointClientHttpInfoMethod,
216
- ): kt.Function<Builder> {
217
- const { endpoint, parameters, responseSchema } = args;
218
-
219
- return kt.function(toCasing(args.endpoint.name, ctx.config.functionNameCasing) + 'WithHttpInfo', {
220
- doc: kt.doc(endpoint.summary, [
221
- kt.docTag('throws', 'IllegalStateException', 'If the request is not correctly configured'),
222
- kt.docTag('throws', 'IOException', 'Rethrows the OkHttp execute method exception'),
223
- ]),
224
- annotations: [
225
- kt.annotation(kt.refs.throws(), [
226
- kt.refs.java.illegalStateException({ classReference: true }),
227
- kt.refs.java.ioException({ classReference: true }),
228
- ]),
229
- endpoint.deprecated ? kt.annotation(kt.refs.deprecated(), [kt.argument(kt.string(''))]) : null,
230
- ],
231
- parameters: parameters.map((p) =>
232
- kt.parameter(
233
- toCasing(p.name, ctx.config.parameterNameCasing),
234
- this.getParameterType(ctx, { endpoint, parameter: p }),
235
- {
236
- description: p.description,
237
- default: !p.required ? kt.toNode(p.schema?.default) : null,
238
- },
239
- )
240
- ),
241
- returnType: ctx.refs.apiResponse([
242
- this.getTypeUsage(ctx, { schema: responseSchema, fallback: kt.refs.unit({ nullable: true }), nullable: true }),
243
- ]),
244
- body: this.getEndpointClientHttpInfoMethodBody(ctx, { endpoint, parameters, responseSchema }),
245
- });
246
- }
247
-
248
- protected getEndpointClientHttpInfoMethodBody(
249
- ctx: Context,
250
- args: Args.GetEndpointClientHttpInfoMethodBody,
251
- ): AppendValueGroup<Builder> {
252
- const { endpoint, parameters, responseSchema } = args;
253
-
254
- return appendValueGroup(
255
- [
256
- s`val localVariableConfig = ${
257
- kt.call(
258
- [toCasing(endpoint.name, 'camel') + 'RequestConfig'],
259
- parameters.map((x) => toCasing(x.name, ctx.config.parameterNameCasing)),
260
- )
261
- }`,
262
- s`return ${
263
- kt.call(
264
- [
265
- kt.reference('request', null, {
266
- generics: [
267
- this.getRequestBodyType(ctx, { endpoint }),
268
- this.getTypeUsage(ctx, { schema: responseSchema, fallback: kt.refs.unit() }),
269
- ],
270
- }),
271
- ],
272
- ['localVariableConfig'],
273
- )
274
- }`,
275
- ],
276
- '\n',
277
- );
278
- }
279
-
280
- protected getEndpointClientRequestConfigMethod(
281
- ctx: Context,
282
- args: Args.GetEndpointClientRequestConfigMethod,
283
- ): kt.Function<Builder> {
284
- const { endpoint, parameters } = args;
285
- const operationName = toCasing(endpoint.name, ctx.config.functionNameCasing);
286
-
287
- return kt.function(toCasing(args.endpoint.name, ctx.config.functionNameCasing) + 'RequestConfig', {
288
- accessModifier: 'private',
289
- doc: kt.doc(`To obtain the request config of the operation ${operationName}`),
290
- annotations: [endpoint.deprecated ? kt.annotation(kt.refs.deprecated(), [kt.argument(kt.string(''))]) : null],
291
- parameters: parameters.map((p) =>
292
- kt.parameter(
293
- toCasing(p.name, ctx.config.parameterNameCasing),
294
- this.getParameterType(ctx, { endpoint, parameter: p }),
295
- {
296
- description: p.description,
297
- default: !p.required ? kt.toNode(p.schema?.default) : null,
298
- },
299
- )
300
- ),
301
- returnType: ctx.refs.requestConfig([this.getRequestBodyType(ctx, { endpoint })]),
302
- body: this.getEndpointClientRequestConfigMethodBody(ctx, { endpoint, parameters }),
303
- });
304
- }
305
-
306
- protected getEndpointClientRequestConfigMethodBody(
307
- ctx: Context,
308
- args: Args.GetEndpointClientRequestConfigMethodBody,
309
- ): AppendValueGroup<Builder> {
310
- const { endpoint, parameters } = args;
311
- const queryParameters = parameters.filter((x) => x.target === 'query');
312
- const headerParameters = parameters.filter((x) => x.target === 'header');
313
- const result = appendValueGroup<Builder>([], '\n');
314
-
315
- if (endpoint.requestBody) {
316
- if (endpoint.requestBody.content[0]?.type === 'multipart/form-data') {
317
- const partConfigs = parameters
318
- .filter((x) => x.multipart)
319
- .map<KtValue<Builder>>((param) => {
320
- const paramName = toCasing(param.name, ctx.config.parameterNameCasing);
321
- return s`"${param.multipart?.name ?? ''}" to ${ctx.refs.partConfig.infer()}(body = ${paramName})`;
322
- });
323
- result.values.push(
324
- s`val localVariableBody = ${
325
- kt.call(kt.refs.mapOf([kt.refs.string(), ctx.refs.partConfig(['*'])]), partConfigs)
326
- }`,
327
- );
328
- } else {
329
- const bodyParamName = toCasing(this.getRequestBodyParamName(ctx, { endpoint }), ctx.config.parameterNameCasing);
330
- result.values.push(`val localVariableBody = ${bodyParamName}`);
331
- }
332
- }
333
-
334
- result.values.push(
335
- s`val localVariableQuery: ${ctx.refs.multiValueMap()} = ${
336
- kt.call(
337
- [kt.refs.mutableMapOf([kt.refs.string(), kt.refs.list([kt.refs.string()])])],
338
- [],
339
- )
340
- }${
341
- queryParameters.length === 0 ? '' : s.indent`
342
- .apply {${s.indent`
343
- ${
344
- appendValueGroup(
345
- queryParameters.map((param) => {
346
- const paramName = toCasing(param.name, ctx.config.parameterNameCasing);
347
- const toString = this.getParameterToString(ctx, { endpoint, parameter: param });
348
- const put = s<Builder>`put(${kt.string(paramName)}, listOf(${paramName}${toString}))`;
349
- return param.required ? put : s<Builder>`if (${paramName} != null) {${s.indent`
350
- ${put}`}
351
- }`;
352
- }),
353
- '\n',
354
- )
355
- }`}
356
- }`
357
- }`,
358
- );
359
-
360
- result.values.push('val localVariableHeaders: MutableMap<String, String> = mutableMapOf()');
361
- if (endpoint.requestBody?.content[0] !== undefined) {
362
- result.values.push(`localVariableHeaders["Content-Type"] = "${endpoint.requestBody?.content[0].type}"`);
363
- }
364
- for (const header of headerParameters) {
365
- const paramName = toCasing(header.name, ctx.config.parameterNameCasing);
366
- const toString = this.getParameterToString(ctx, { endpoint, parameter: header });
367
- result.values.push(
368
- s`if (${paramName} != null) {${s.indent`
369
- localVariableHeaders["${header.name}"] = ${paramName}${toString}`}
370
- }`,
371
- );
372
- }
373
-
374
- result.values.push(
375
- s`return ${
376
- kt.call(
377
- [ctx.refs.requestConfig.infer()],
378
- [
379
- kt.argument.named('method', kt.call([ctx.refs.requestMethod(), endpoint.method.toUpperCase()])),
380
- kt.argument.named('path', kt.string(this.getPathWithInterpolation(ctx, { endpoint }), { template: true })),
381
- kt.argument.named('query', 'localVariableQuery'),
382
- kt.argument.named('headers', 'localVariableHeaders'),
383
- kt.argument.named('requiresAuthentication', 'false'),
384
- endpoint.requestBody ? kt.argument.named('body', 'localVariableBody') : null,
385
- ],
386
- )
387
- }`,
388
- );
389
-
390
- return result;
391
- }
392
-
393
- protected getParameterToString(ctx: Context, args: Args.GetParameterToString): kt.Value<Builder> {
394
- const { parameter } = args;
395
- if (parameter.schema?.kind === 'array') {
396
- return '.joinToString()';
397
- } else if (
398
- parameter.schema?.kind === 'string' && parameter.schema.enum?.length &&
399
- this.getSchemaType(ctx, { schema: parameter.schema })
400
- ) {
401
- return '.value';
402
- } else {
403
- return '.toString()';
404
- }
405
- }
406
-
407
- protected getAdditionalClientMembers(
408
- _ctx: Context,
409
- _args: Args.GetAdditionalClientMembers,
410
- ): kt.ClassMember<Builder>[] {
411
- return [
412
- kt.function('encodeURIComponent', {
413
- accessModifier: 'private',
414
- parameters: [kt.parameter('uriComponent', kt.refs.string())],
415
- returnType: kt.refs.string(),
416
- singleExpression: true,
417
- body:
418
- s`${kt.refs.okhttp3.httpUrl()}.Builder().scheme("http").host("localhost").addPathSegment(uriComponent).build().encodedPathSegments[0]`,
419
- }),
420
- ];
421
- }
422
-
423
- protected getParameterType(ctx: Context, args: Args.GetParameterType): kt.Type<Builder> {
424
- const { parameter } = args;
425
- if (parameter.multipart?.isFile) {
426
- return kt.refs.java.file();
427
- }
428
- return this.getTypeUsage(ctx, {
429
- schema: parameter.schema,
430
- nullable: !parameter.required,
431
- });
432
- }
433
-
434
- protected getRequestBodyType(ctx: Context, args: Args.GetRequestBodyType): kt.Type<Builder> {
435
- const { endpoint } = args;
436
- const content = endpoint.requestBody?.content[0];
437
- return content?.type === 'multipart/form-data'
438
- ? kt.refs.map([kt.refs.string(), ctx.refs.partConfig(['*'])])
439
- : this.getTypeUsage(ctx, { schema: content?.schema, fallback: kt.refs.unit() });
440
- }
441
-
442
- protected getTypeUsage(ctx: Context, args: Args.GetTypeUsage<Builder>): kt.Type<Builder> {
443
- const { schema, nullable, fallback } = args;
444
- const type = this.getSchemaType(ctx, { schema });
445
- return type
446
- ? createOverwriteProxy(type, { nullable: nullable ?? type.nullable })
447
- : (fallback ?? kt.refs.any({ nullable }));
448
- }
449
-
450
- protected getPackageName(ctx: Context, _args: Args.GetPackageName): string {
451
- const packageSuffix = typeof ctx.config.packageSuffix === 'string'
452
- ? ctx.config.packageSuffix
453
- : ctx.config.packageSuffix(ctx.service);
454
- return ctx.config.packageName + packageSuffix;
455
- }
456
-
457
- protected getPathWithInterpolation(ctx: Context, args: Args.GetPathWithInterpolation): string {
458
- const { endpoint } = args;
459
- let path = this.getEndpointPath(ctx, { endpoint });
460
- endpoint.parameters
461
- .filter((x) => x.target === 'path')
462
- .forEach((parameter) => {
463
- path = path.replace(
464
- `{${parameter.name}}`,
465
- `\${encodeURIComponent(${toCasing(parameter.name, 'camel')}${
466
- this.getParameterToString(ctx, { endpoint, parameter })
467
- })}`,
468
- );
469
- });
470
- return path;
471
- }
472
-
473
- protected getResponseSchema(_ctx: Context, args: Args.GetResponseSchema): ApiSchema | undefined {
474
- const { endpoint } = args;
475
- return endpoint.responses.find((x) => !x.statusCode || (x.statusCode >= 200 && x.statusCode < 300))
476
- ?.contentOptions[0]?.schema;
477
- }
478
-
479
- protected getSchemaType(ctx: Context, args: Args.GetSchemaType): kt.Reference<SourceBuilder> | undefined {
480
- const { schema } = args;
481
- return schema && ctx.input.kotlin.models[schema.id].type;
482
- }
483
-
484
- protected getAllParameters(ctx: Context, args: Args.GetAllParameters): ApiParameterWithMultipartInfo[] {
485
- const { endpoint } = args;
486
- const parameters = endpoint.parameters.filter(
487
- (parameter) => parameter.target === 'query' || parameter.target === 'path' || parameter.target === 'header',
488
- );
489
- if (endpoint.requestBody) {
490
- const content = endpoint.requestBody.content[0];
491
- let schema = content.schema;
492
-
493
- if (content.type === 'multipart/form-data') {
494
- if (schema && schema.kind === 'object') {
495
- schema = resolveAnyOfAndAllOf(schema, true) ?? schema;
496
- const properties = schema.properties ?? {};
497
- for (const [name, property] of properties.entries()) {
498
- parameters.push(
499
- Object.assign(
500
- this.createApiParameter({
501
- id: `multipart-${name}`,
502
- name,
503
- target: 'body',
504
- schema: property.schema,
505
- required: schema.required.has(name),
506
- description: property.schema.description,
507
- }),
508
- {
509
- multipart: {
510
- name,
511
- isFile: property.schema.kind === 'string' && property.schema.format === 'binary',
512
- },
513
- },
514
- ),
515
- );
516
- }
517
- }
518
- } else {
519
- parameters.push(
520
- this.createApiParameter({
521
- id: 'body',
522
- name: this.getRequestBodyParamName(ctx, { endpoint }),
523
- target: 'body',
524
- schema,
525
- required: endpoint.requestBody.required,
526
- description: endpoint.requestBody.description,
527
- }),
528
- );
529
- }
530
- }
531
-
532
- return parameters.sort((a, b) => (a.required === b.required ? 0 : a.required ? -1 : 1));
533
- }
534
-
535
- protected getRequestBodyParamName(ctx: Context, args: Args.GetRequestBodyParamName): string {
536
- const { endpoint } = args;
537
- const schema = endpoint.requestBody?.content[0].schema;
538
- const schemaInfo = this.getSchemaType(ctx, { schema });
539
- return toCasing(
540
- schemaInfo && schemaInfo.name !== 'Any' ? SourceBuilder.build((b) => kt.reference.write(b, schemaInfo)) : 'body',
541
- ctx.config.parameterNameCasing,
542
- );
543
- }
544
-
545
- protected getBasePath(ctx: Context, _args: Args.GetBasePath): string {
546
- return modifyString(
547
- (ctx.service.$src ?? ctx.service.endpoints[0]?.$src)?.document.servers?.[0]?.url ?? '/',
548
- ctx.config.basePath,
549
- ctx.service,
550
- );
551
- }
552
-
553
- protected getEndpointPath(ctx: Context, args: Args.GetEndpointPath): string {
554
- const { endpoint } = args;
555
- return modifyString(endpoint.path, ctx.config.pathModifier, endpoint);
556
- }
557
-
558
- protected getFilePath(ctx: Context, args: Args.GetFilePath): string {
559
- const { packageName } = args;
560
- return `${ctx.config.outputDir}/${packageName.replace(/\./g, '/')}/${this.getApiClientName(ctx, {})}.kt`;
561
- }
562
-
563
- protected getApiClientName(ctx: Context, _args: Args.GetApiClientName): string {
564
- return toCasing(ctx.service.name, ctx.config.typeNameCasing) + 'ApiClient';
565
- }
566
-
567
- private createApiParameter(data: Partial<ApiParameter> & Pick<ApiParameter, 'id' | 'name' | 'target'>): ApiParameter {
568
- return {
569
- // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
570
- $src: undefined!,
571
- $ref: undefined,
572
- schema: undefined,
573
- required: false,
574
- description: undefined,
575
- allowEmptyValue: undefined,
576
- allowReserved: undefined,
577
- deprecated: false,
578
- explode: undefined,
579
- style: undefined,
580
- ...data,
581
- };
582
- }
583
- }