@goast/kotlin 0.4.2-beta1 → 0.4.3

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 (494) 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.7/assertion_error.d.ts +26 -0
  11. package/esm/deps/jsr.io/@std/assert/1.0.7/assertion_error.d.ts.map +1 -0
  12. package/esm/deps/jsr.io/@std/assert/1.0.7/assertion_error.js +30 -0
  13. package/esm/deps/jsr.io/@std/assert/1.0.7/equal.d.ts +17 -0
  14. package/esm/deps/jsr.io/@std/assert/1.0.7/equal.d.ts.map +1 -0
  15. package/esm/deps/jsr.io/@std/assert/1.0.7/equal.js +136 -0
  16. package/esm/deps/jsr.io/@std/assert/1.0.7/equals.d.ts +22 -0
  17. package/esm/deps/jsr.io/@std/assert/1.0.7/equals.d.ts.map +1 -0
  18. package/esm/deps/jsr.io/@std/assert/1.0.7/equals.js +45 -0
  19. package/esm/deps/jsr.io/@std/assert/1.0.7/false.d.ts +18 -0
  20. package/esm/deps/jsr.io/@std/assert/1.0.7/false.d.ts.map +1 -0
  21. package/esm/deps/jsr.io/@std/assert/1.0.7/false.js +22 -0
  22. package/esm/deps/jsr.io/@std/assert/1.0.7/instance_of.d.ts +23 -0
  23. package/esm/deps/jsr.io/@std/assert/1.0.7/instance_of.d.ts.map +1 -0
  24. package/esm/deps/jsr.io/@std/assert/1.0.7/instance_of.js +53 -0
  25. package/esm/deps/jsr.io/@std/assert/1.0.7/is_error.d.ts +25 -0
  26. package/esm/deps/jsr.io/@std/assert/1.0.7/is_error.d.ts.map +1 -0
  27. package/esm/deps/jsr.io/@std/assert/1.0.7/is_error.js +54 -0
  28. package/esm/deps/jsr.io/@std/assert/1.0.7/match.d.ts +18 -0
  29. package/esm/deps/jsr.io/@std/assert/1.0.7/match.d.ts.map +1 -0
  30. package/esm/deps/jsr.io/@std/assert/1.0.7/match.js +26 -0
  31. package/esm/deps/jsr.io/@std/assert/1.0.7/not_instance_of.d.ts +20 -0
  32. package/esm/deps/jsr.io/@std/assert/1.0.7/not_instance_of.d.ts.map +1 -0
  33. package/esm/deps/jsr.io/@std/assert/1.0.7/not_instance_of.js +29 -0
  34. package/esm/deps/jsr.io/@std/assert/1.0.7/not_match.d.ts +18 -0
  35. package/esm/deps/jsr.io/@std/assert/1.0.7/not_match.d.ts.map +1 -0
  36. package/esm/deps/jsr.io/@std/assert/1.0.7/not_match.js +26 -0
  37. package/esm/deps/jsr.io/@std/assert/1.0.7/not_strict_equals.d.ts +23 -0
  38. package/esm/deps/jsr.io/@std/assert/1.0.7/not_strict_equals.d.ts.map +1 -0
  39. package/esm/deps/jsr.io/@std/assert/1.0.7/not_strict_equals.js +32 -0
  40. package/esm/deps/jsr.io/@std/assert/1.0.7/rejects.d.ts +42 -0
  41. package/esm/deps/jsr.io/@std/assert/1.0.7/rejects.d.ts.map +1 -0
  42. package/esm/deps/jsr.io/@std/assert/1.0.7/rejects.js +53 -0
  43. package/esm/deps/jsr.io/@std/assert/1.0.7/strict_equals.d.ts +24 -0
  44. package/esm/deps/jsr.io/@std/assert/1.0.7/strict_equals.d.ts.map +1 -0
  45. package/esm/deps/jsr.io/@std/assert/1.0.7/strict_equals.js +57 -0
  46. package/esm/deps/jsr.io/@std/expect/1.0.7/_assert_equals.d.ts +20 -0
  47. package/esm/deps/jsr.io/@std/expect/1.0.7/_assert_equals.d.ts.map +1 -0
  48. package/esm/deps/jsr.io/@std/expect/1.0.7/_assert_equals.js +29 -0
  49. package/esm/deps/jsr.io/@std/expect/1.0.7/_assert_not_equals.d.ts +17 -0
  50. package/esm/deps/jsr.io/@std/expect/1.0.7/_assert_not_equals.d.ts.map +1 -0
  51. package/esm/deps/jsr.io/@std/expect/1.0.7/_assert_not_equals.js +26 -0
  52. package/esm/deps/jsr.io/@std/expect/1.0.7/_assertions.d.ts +4 -0
  53. package/esm/deps/jsr.io/@std/expect/1.0.7/_assertions.d.ts.map +1 -0
  54. package/esm/deps/jsr.io/@std/expect/1.0.7/_assertions.js +13 -0
  55. package/esm/deps/jsr.io/@std/expect/1.0.7/_asymmetric_matchers.d.ts +46 -0
  56. package/esm/deps/jsr.io/@std/expect/1.0.7/_asymmetric_matchers.d.ts.map +1 -0
  57. package/esm/deps/jsr.io/@std/expect/1.0.7/_asymmetric_matchers.js +160 -0
  58. package/esm/deps/jsr.io/@std/expect/1.0.7/_build_message.d.ts +6 -0
  59. package/esm/deps/jsr.io/@std/expect/1.0.7/_build_message.d.ts.map +1 -0
  60. package/esm/deps/jsr.io/@std/expect/1.0.7/_build_message.js +29 -0
  61. package/esm/deps/jsr.io/@std/expect/1.0.7/_custom_equality_tester.d.ts +4 -0
  62. package/esm/deps/jsr.io/@std/expect/1.0.7/_custom_equality_tester.d.ts.map +1 -0
  63. package/esm/deps/jsr.io/@std/expect/1.0.7/_custom_equality_tester.js +11 -0
  64. package/esm/deps/jsr.io/@std/expect/1.0.7/_equal.d.ts +9 -0
  65. package/esm/deps/jsr.io/@std/expect/1.0.7/_equal.d.ts.map +1 -0
  66. package/esm/deps/jsr.io/@std/expect/1.0.7/_equal.js +191 -0
  67. package/esm/deps/jsr.io/@std/expect/1.0.7/_extend.d.ts +4 -0
  68. package/esm/deps/jsr.io/@std/expect/1.0.7/_extend.d.ts.map +1 -0
  69. package/esm/deps/jsr.io/@std/expect/1.0.7/_extend.js +11 -0
  70. package/esm/deps/jsr.io/@std/expect/1.0.7/_inspect_args.d.ts +3 -0
  71. package/esm/deps/jsr.io/@std/expect/1.0.7/_inspect_args.d.ts.map +1 -0
  72. package/esm/deps/jsr.io/@std/expect/1.0.7/_inspect_args.js +12 -0
  73. package/esm/deps/jsr.io/@std/expect/1.0.7/_matchers.d.ts +34 -0
  74. package/esm/deps/jsr.io/@std/expect/1.0.7/_matchers.d.ts.map +1 -0
  75. package/esm/deps/jsr.io/@std/expect/1.0.7/_matchers.js +563 -0
  76. package/esm/deps/jsr.io/@std/expect/1.0.7/_mock_util.d.ts +11 -0
  77. package/esm/deps/jsr.io/@std/expect/1.0.7/_mock_util.d.ts.map +1 -0
  78. package/esm/deps/jsr.io/@std/expect/1.0.7/_mock_util.js +10 -0
  79. package/esm/deps/jsr.io/@std/expect/1.0.7/_types.d.ts +838 -0
  80. package/esm/deps/jsr.io/@std/expect/1.0.7/_types.d.ts.map +1 -0
  81. package/esm/deps/jsr.io/@std/expect/1.0.7/_types.js +3 -0
  82. package/esm/deps/jsr.io/@std/expect/1.0.7/_utils.d.ts +9 -0
  83. package/esm/deps/jsr.io/@std/expect/1.0.7/_utils.d.ts.map +1 -0
  84. package/esm/deps/jsr.io/@std/expect/1.0.7/_utils.js +218 -0
  85. package/esm/deps/jsr.io/@std/expect/1.0.7/expect.d.ts +59 -0
  86. package/esm/deps/jsr.io/@std/expect/1.0.7/expect.d.ts.map +1 -0
  87. package/esm/deps/jsr.io/@std/expect/1.0.7/expect.js +506 -0
  88. package/esm/deps/jsr.io/@std/internal/1.0.5/assertion_state.d.ts +160 -0
  89. package/esm/deps/jsr.io/@std/internal/1.0.5/assertion_state.d.ts.map +1 -0
  90. package/esm/deps/jsr.io/@std/internal/1.0.5/assertion_state.js +199 -0
  91. package/esm/deps/jsr.io/@std/internal/1.0.5/build_message.d.ts +82 -0
  92. package/esm/deps/jsr.io/@std/internal/1.0.5/build_message.d.ts.map +1 -0
  93. package/esm/deps/jsr.io/@std/internal/1.0.5/build_message.js +111 -0
  94. package/esm/deps/jsr.io/@std/internal/1.0.5/diff.d.ts +140 -0
  95. package/esm/deps/jsr.io/@std/internal/1.0.5/diff.d.ts.map +1 -0
  96. package/esm/deps/jsr.io/@std/internal/1.0.5/diff.js +277 -0
  97. package/esm/deps/jsr.io/@std/internal/1.0.5/diff_str.d.ts +99 -0
  98. package/esm/deps/jsr.io/@std/internal/1.0.5/diff_str.d.ts.map +1 -0
  99. package/esm/deps/jsr.io/@std/internal/1.0.5/diff_str.js +180 -0
  100. package/esm/deps/jsr.io/@std/internal/1.0.5/format.d.ts +2 -0
  101. package/esm/deps/jsr.io/@std/internal/1.0.5/format.d.ts.map +1 -0
  102. package/esm/deps/jsr.io/@std/internal/1.0.5/format.js +37 -0
  103. package/esm/deps/jsr.io/@std/internal/1.0.5/styles.d.ts +159 -0
  104. package/esm/deps/jsr.io/@std/internal/1.0.5/styles.d.ts.map +1 -0
  105. package/esm/deps/jsr.io/@std/internal/1.0.5/styles.js +207 -0
  106. package/esm/deps/jsr.io/@std/internal/1.0.5/types.d.ts +16 -0
  107. package/esm/deps/jsr.io/@std/internal/1.0.5/types.d.ts.map +1 -0
  108. package/esm/deps/jsr.io/@std/internal/1.0.5/types.js +2 -0
  109. package/esm/deps/jsr.io/@std/testing/1.0.4/_mock_utils.d.ts +15 -0
  110. package/esm/deps/jsr.io/@std/testing/1.0.4/_mock_utils.d.ts.map +1 -0
  111. package/esm/deps/jsr.io/@std/testing/1.0.4/_mock_utils.js +35 -0
  112. package/esm/deps/jsr.io/@std/testing/1.0.4/_test_suite.d.ts +74 -0
  113. package/esm/deps/jsr.io/@std/testing/1.0.4/_test_suite.d.ts.map +1 -0
  114. package/esm/deps/jsr.io/@std/testing/1.0.4/_test_suite.js +350 -0
  115. package/esm/deps/jsr.io/@std/testing/1.0.4/bdd.d.ts +731 -0
  116. package/esm/deps/jsr.io/@std/testing/1.0.4/bdd.d.ts.map +1 -0
  117. package/esm/deps/jsr.io/@std/testing/1.0.4/bdd.js +581 -0
  118. package/esm/deps/jsr.io/@std/testing/1.0.4/mock.d.ts +674 -0
  119. package/esm/deps/jsr.io/@std/testing/1.0.4/mock.d.ts.map +1 -0
  120. package/esm/deps/jsr.io/@std/testing/1.0.4/mock.js +1083 -0
  121. package/esm/src/ast/nodes/annotation.test.d.ts +2 -0
  122. package/esm/src/ast/nodes/annotation.test.d.ts.map +1 -0
  123. package/esm/src/ast/nodes/annotation.test.js +56 -0
  124. package/esm/src/ast/nodes/argument.test.d.ts +2 -0
  125. package/esm/src/ast/nodes/argument.test.d.ts.map +1 -0
  126. package/esm/src/ast/nodes/argument.test.js +33 -0
  127. package/esm/src/ast/nodes/call.test.d.ts +2 -0
  128. package/esm/src/ast/nodes/call.test.d.ts.map +1 -0
  129. package/esm/src/ast/nodes/call.test.js +35 -0
  130. package/esm/src/ast/nodes/class.test.d.ts +2 -0
  131. package/esm/src/ast/nodes/class.test.d.ts.map +1 -0
  132. package/esm/src/ast/nodes/class.test.js +219 -0
  133. package/esm/src/ast/nodes/constructor.test.d.ts +2 -0
  134. package/esm/src/ast/nodes/constructor.test.d.ts.map +1 -0
  135. package/esm/src/ast/nodes/constructor.test.js +139 -0
  136. package/esm/src/ast/nodes/doc-tag.test.d.ts +2 -0
  137. package/esm/src/ast/nodes/doc-tag.test.d.ts.map +1 -0
  138. package/esm/src/ast/nodes/doc-tag.test.js +67 -0
  139. package/esm/src/ast/nodes/doc.test.d.ts +2 -0
  140. package/esm/src/ast/nodes/doc.test.d.ts.map +1 -0
  141. package/esm/src/ast/nodes/doc.test.js +33 -0
  142. package/esm/src/ast/nodes/enum-value.test.d.ts +2 -0
  143. package/esm/src/ast/nodes/enum-value.test.d.ts.map +1 -0
  144. package/esm/src/ast/nodes/enum-value.test.js +115 -0
  145. package/esm/src/ast/nodes/enum.test.d.ts +2 -0
  146. package/esm/src/ast/nodes/enum.test.d.ts.map +1 -0
  147. package/esm/src/ast/nodes/enum.test.js +129 -0
  148. package/esm/src/ast/nodes/function.test.d.ts +2 -0
  149. package/esm/src/ast/nodes/function.test.d.ts.map +1 -0
  150. package/esm/src/ast/nodes/function.test.js +160 -0
  151. package/esm/src/ast/nodes/generic-parameter.test.d.ts +2 -0
  152. package/esm/src/ast/nodes/generic-parameter.test.d.ts.map +1 -0
  153. package/esm/src/ast/nodes/generic-parameter.test.js +49 -0
  154. package/esm/src/ast/nodes/init-block.test.d.ts +2 -0
  155. package/esm/src/ast/nodes/init-block.test.d.ts.map +1 -0
  156. package/esm/src/ast/nodes/init-block.test.js +28 -0
  157. package/esm/src/ast/nodes/interface.test.d.ts +2 -0
  158. package/esm/src/ast/nodes/interface.test.d.ts.map +1 -0
  159. package/esm/src/ast/nodes/interface.test.js +121 -0
  160. package/esm/src/ast/nodes/object.test.d.ts +2 -0
  161. package/esm/src/ast/nodes/object.test.d.ts.map +1 -0
  162. package/esm/src/ast/nodes/object.test.js +78 -0
  163. package/esm/src/ast/nodes/parameter.test.d.ts +2 -0
  164. package/esm/src/ast/nodes/parameter.test.d.ts.map +1 -0
  165. package/esm/src/ast/nodes/parameter.test.js +152 -0
  166. package/esm/src/ast/nodes/property.test.d.ts +2 -0
  167. package/esm/src/ast/nodes/property.test.d.ts.map +1 -0
  168. package/esm/src/ast/nodes/property.test.js +206 -0
  169. package/esm/src/ast/nodes/reference.test.d.ts +2 -0
  170. package/esm/src/ast/nodes/reference.test.d.ts.map +1 -0
  171. package/esm/src/ast/nodes/reference.test.js +36 -0
  172. package/esm/src/ast/nodes/string.test.d.ts +2 -0
  173. package/esm/src/ast/nodes/string.test.d.ts.map +1 -0
  174. package/esm/src/ast/nodes/string.test.js +48 -0
  175. package/esm/src/generators/services/okhttp3-clients/okhttp3-client-generator.js +26 -26
  176. package/esm/src/generators/services/spring-controllers/spring-controller-generator.d.ts.map +1 -1
  177. package/esm/src/generators/services/spring-controllers/spring-controller-generator.js +11 -7
  178. package/esm/src/import-collection.test.d.ts +2 -0
  179. package/esm/src/import-collection.test.d.ts.map +1 -0
  180. package/esm/src/import-collection.test.js +99 -0
  181. package/esm/tests/openapi-models.test.d.ts +2 -0
  182. package/esm/tests/openapi-models.test.d.ts.map +1 -0
  183. package/esm/tests/openapi-models.test.js +45 -0
  184. package/package.json +2 -2
  185. package/script/_dnt.test_polyfills.d.ts +29 -0
  186. package/script/_dnt.test_polyfills.d.ts.map +1 -0
  187. package/script/_dnt.test_polyfills.js +32 -0
  188. package/script/_dnt.test_shims.d.ts +6 -0
  189. package/script/_dnt.test_shims.d.ts.map +1 -0
  190. package/script/_dnt.test_shims.js +65 -0
  191. package/script/deps/jsr.io/@std/assert/1.0.7/assertion_error.d.ts +26 -0
  192. package/script/deps/jsr.io/@std/assert/1.0.7/assertion_error.d.ts.map +1 -0
  193. package/script/deps/jsr.io/@std/assert/1.0.7/assertion_error.js +34 -0
  194. package/script/deps/jsr.io/@std/assert/1.0.7/equal.d.ts +17 -0
  195. package/script/deps/jsr.io/@std/assert/1.0.7/equal.d.ts.map +1 -0
  196. package/script/deps/jsr.io/@std/assert/1.0.7/equal.js +139 -0
  197. package/script/deps/jsr.io/@std/assert/1.0.7/equals.d.ts +22 -0
  198. package/script/deps/jsr.io/@std/assert/1.0.7/equals.d.ts.map +1 -0
  199. package/script/deps/jsr.io/@std/assert/1.0.7/equals.js +48 -0
  200. package/script/deps/jsr.io/@std/assert/1.0.7/false.d.ts +18 -0
  201. package/script/deps/jsr.io/@std/assert/1.0.7/false.d.ts.map +1 -0
  202. package/script/deps/jsr.io/@std/assert/1.0.7/false.js +25 -0
  203. package/script/deps/jsr.io/@std/assert/1.0.7/instance_of.d.ts +23 -0
  204. package/script/deps/jsr.io/@std/assert/1.0.7/instance_of.d.ts.map +1 -0
  205. package/script/deps/jsr.io/@std/assert/1.0.7/instance_of.js +56 -0
  206. package/script/deps/jsr.io/@std/assert/1.0.7/is_error.d.ts +25 -0
  207. package/script/deps/jsr.io/@std/assert/1.0.7/is_error.d.ts.map +1 -0
  208. package/script/deps/jsr.io/@std/assert/1.0.7/is_error.js +57 -0
  209. package/script/deps/jsr.io/@std/assert/1.0.7/match.d.ts +18 -0
  210. package/script/deps/jsr.io/@std/assert/1.0.7/match.d.ts.map +1 -0
  211. package/script/deps/jsr.io/@std/assert/1.0.7/match.js +29 -0
  212. package/script/deps/jsr.io/@std/assert/1.0.7/not_instance_of.d.ts +20 -0
  213. package/script/deps/jsr.io/@std/assert/1.0.7/not_instance_of.d.ts.map +1 -0
  214. package/script/deps/jsr.io/@std/assert/1.0.7/not_instance_of.js +32 -0
  215. package/script/deps/jsr.io/@std/assert/1.0.7/not_match.d.ts +18 -0
  216. package/script/deps/jsr.io/@std/assert/1.0.7/not_match.d.ts.map +1 -0
  217. package/script/deps/jsr.io/@std/assert/1.0.7/not_match.js +29 -0
  218. package/script/deps/jsr.io/@std/assert/1.0.7/not_strict_equals.d.ts +23 -0
  219. package/script/deps/jsr.io/@std/assert/1.0.7/not_strict_equals.d.ts.map +1 -0
  220. package/script/deps/jsr.io/@std/assert/1.0.7/not_strict_equals.js +35 -0
  221. package/script/deps/jsr.io/@std/assert/1.0.7/rejects.d.ts +42 -0
  222. package/script/deps/jsr.io/@std/assert/1.0.7/rejects.d.ts.map +1 -0
  223. package/script/deps/jsr.io/@std/assert/1.0.7/rejects.js +56 -0
  224. package/script/deps/jsr.io/@std/assert/1.0.7/strict_equals.d.ts +24 -0
  225. package/script/deps/jsr.io/@std/assert/1.0.7/strict_equals.d.ts.map +1 -0
  226. package/script/deps/jsr.io/@std/assert/1.0.7/strict_equals.js +60 -0
  227. package/script/deps/jsr.io/@std/expect/1.0.7/_assert_equals.d.ts +20 -0
  228. package/script/deps/jsr.io/@std/expect/1.0.7/_assert_equals.d.ts.map +1 -0
  229. package/script/deps/jsr.io/@std/expect/1.0.7/_assert_equals.js +32 -0
  230. package/script/deps/jsr.io/@std/expect/1.0.7/_assert_not_equals.d.ts +17 -0
  231. package/script/deps/jsr.io/@std/expect/1.0.7/_assert_not_equals.d.ts.map +1 -0
  232. package/script/deps/jsr.io/@std/expect/1.0.7/_assert_not_equals.js +29 -0
  233. package/script/deps/jsr.io/@std/expect/1.0.7/_assertions.d.ts +4 -0
  234. package/script/deps/jsr.io/@std/expect/1.0.7/_assertions.d.ts.map +1 -0
  235. package/script/deps/jsr.io/@std/expect/1.0.7/_assertions.js +18 -0
  236. package/script/deps/jsr.io/@std/expect/1.0.7/_asymmetric_matchers.d.ts +46 -0
  237. package/script/deps/jsr.io/@std/expect/1.0.7/_asymmetric_matchers.d.ts.map +1 -0
  238. package/script/deps/jsr.io/@std/expect/1.0.7/_asymmetric_matchers.js +182 -0
  239. package/script/deps/jsr.io/@std/expect/1.0.7/_build_message.d.ts +6 -0
  240. package/script/deps/jsr.io/@std/expect/1.0.7/_build_message.d.ts.map +1 -0
  241. package/script/deps/jsr.io/@std/expect/1.0.7/_build_message.js +33 -0
  242. package/script/deps/jsr.io/@std/expect/1.0.7/_custom_equality_tester.d.ts +4 -0
  243. package/script/deps/jsr.io/@std/expect/1.0.7/_custom_equality_tester.d.ts.map +1 -0
  244. package/script/deps/jsr.io/@std/expect/1.0.7/_custom_equality_tester.js +15 -0
  245. package/script/deps/jsr.io/@std/expect/1.0.7/_equal.d.ts +9 -0
  246. package/script/deps/jsr.io/@std/expect/1.0.7/_equal.d.ts.map +1 -0
  247. package/script/deps/jsr.io/@std/expect/1.0.7/_equal.js +194 -0
  248. package/script/deps/jsr.io/@std/expect/1.0.7/_extend.d.ts +4 -0
  249. package/script/deps/jsr.io/@std/expect/1.0.7/_extend.d.ts.map +1 -0
  250. package/script/deps/jsr.io/@std/expect/1.0.7/_extend.js +15 -0
  251. package/script/deps/jsr.io/@std/expect/1.0.7/_inspect_args.d.ts +3 -0
  252. package/script/deps/jsr.io/@std/expect/1.0.7/_inspect_args.d.ts.map +1 -0
  253. package/script/deps/jsr.io/@std/expect/1.0.7/_inspect_args.js +17 -0
  254. package/script/deps/jsr.io/@std/expect/1.0.7/_matchers.d.ts +34 -0
  255. package/script/deps/jsr.io/@std/expect/1.0.7/_matchers.d.ts.map +1 -0
  256. package/script/deps/jsr.io/@std/expect/1.0.7/_matchers.js +597 -0
  257. package/script/deps/jsr.io/@std/expect/1.0.7/_mock_util.d.ts +11 -0
  258. package/script/deps/jsr.io/@std/expect/1.0.7/_mock_util.d.ts.map +1 -0
  259. package/script/deps/jsr.io/@std/expect/1.0.7/_mock_util.js +14 -0
  260. package/script/deps/jsr.io/@std/expect/1.0.7/_types.d.ts +838 -0
  261. package/script/deps/jsr.io/@std/expect/1.0.7/_types.d.ts.map +1 -0
  262. package/script/deps/jsr.io/@std/expect/1.0.7/_types.js +4 -0
  263. package/script/deps/jsr.io/@std/expect/1.0.7/_utils.d.ts +9 -0
  264. package/script/deps/jsr.io/@std/expect/1.0.7/_utils.d.ts.map +1 -0
  265. package/script/deps/jsr.io/@std/expect/1.0.7/_utils.js +226 -0
  266. package/script/deps/jsr.io/@std/expect/1.0.7/expect.d.ts +59 -0
  267. package/script/deps/jsr.io/@std/expect/1.0.7/expect.d.ts.map +1 -0
  268. package/script/deps/jsr.io/@std/expect/1.0.7/expect.js +510 -0
  269. package/script/deps/jsr.io/@std/internal/1.0.5/assertion_state.d.ts +160 -0
  270. package/script/deps/jsr.io/@std/internal/1.0.5/assertion_state.d.ts.map +1 -0
  271. package/script/deps/jsr.io/@std/internal/1.0.5/assertion_state.js +204 -0
  272. package/script/deps/jsr.io/@std/internal/1.0.5/build_message.d.ts +82 -0
  273. package/script/deps/jsr.io/@std/internal/1.0.5/build_message.d.ts.map +1 -0
  274. package/script/deps/jsr.io/@std/internal/1.0.5/build_message.js +116 -0
  275. package/script/deps/jsr.io/@std/internal/1.0.5/diff.d.ts +140 -0
  276. package/script/deps/jsr.io/@std/internal/1.0.5/diff.d.ts.map +1 -0
  277. package/script/deps/jsr.io/@std/internal/1.0.5/diff.js +284 -0
  278. package/script/deps/jsr.io/@std/internal/1.0.5/diff_str.d.ts +99 -0
  279. package/script/deps/jsr.io/@std/internal/1.0.5/diff_str.d.ts.map +1 -0
  280. package/script/deps/jsr.io/@std/internal/1.0.5/diff_str.js +186 -0
  281. package/script/deps/jsr.io/@std/internal/1.0.5/format.d.ts +2 -0
  282. package/script/deps/jsr.io/@std/internal/1.0.5/format.d.ts.map +1 -0
  283. package/script/deps/jsr.io/@std/internal/1.0.5/format.js +41 -0
  284. package/script/deps/jsr.io/@std/internal/1.0.5/styles.d.ts +159 -0
  285. package/script/deps/jsr.io/@std/internal/1.0.5/styles.d.ts.map +1 -0
  286. package/script/deps/jsr.io/@std/internal/1.0.5/styles.js +220 -0
  287. package/script/deps/jsr.io/@std/internal/1.0.5/types.d.ts +16 -0
  288. package/script/deps/jsr.io/@std/internal/1.0.5/types.d.ts.map +1 -0
  289. package/script/deps/jsr.io/@std/internal/1.0.5/types.js +3 -0
  290. package/script/deps/jsr.io/@std/testing/1.0.4/_mock_utils.d.ts +15 -0
  291. package/script/deps/jsr.io/@std/testing/1.0.4/_mock_utils.d.ts.map +1 -0
  292. package/script/deps/jsr.io/@std/testing/1.0.4/_mock_utils.js +41 -0
  293. package/script/deps/jsr.io/@std/testing/1.0.4/_test_suite.d.ts +74 -0
  294. package/script/deps/jsr.io/@std/testing/1.0.4/_test_suite.d.ts.map +1 -0
  295. package/script/deps/jsr.io/@std/testing/1.0.4/_test_suite.js +355 -0
  296. package/script/deps/jsr.io/@std/testing/1.0.4/bdd.d.ts +731 -0
  297. package/script/deps/jsr.io/@std/testing/1.0.4/bdd.d.ts.map +1 -0
  298. package/script/deps/jsr.io/@std/testing/1.0.4/bdd.js +592 -0
  299. package/script/deps/jsr.io/@std/testing/1.0.4/mock.d.ts +674 -0
  300. package/script/deps/jsr.io/@std/testing/1.0.4/mock.d.ts.map +1 -0
  301. package/script/deps/jsr.io/@std/testing/1.0.4/mock.js +1102 -0
  302. package/script/src/ast/nodes/annotation.test.d.ts +2 -0
  303. package/script/src/ast/nodes/annotation.test.d.ts.map +1 -0
  304. package/script/src/ast/nodes/annotation.test.js +58 -0
  305. package/script/src/ast/nodes/argument.test.d.ts +2 -0
  306. package/script/src/ast/nodes/argument.test.d.ts.map +1 -0
  307. package/script/src/ast/nodes/argument.test.js +35 -0
  308. package/script/src/ast/nodes/call.test.d.ts +2 -0
  309. package/script/src/ast/nodes/call.test.d.ts.map +1 -0
  310. package/script/src/ast/nodes/call.test.js +37 -0
  311. package/script/src/ast/nodes/class.test.d.ts +2 -0
  312. package/script/src/ast/nodes/class.test.d.ts.map +1 -0
  313. package/script/src/ast/nodes/class.test.js +221 -0
  314. package/script/src/ast/nodes/constructor.test.d.ts +2 -0
  315. package/script/src/ast/nodes/constructor.test.d.ts.map +1 -0
  316. package/script/src/ast/nodes/constructor.test.js +141 -0
  317. package/script/src/ast/nodes/doc-tag.test.d.ts +2 -0
  318. package/script/src/ast/nodes/doc-tag.test.d.ts.map +1 -0
  319. package/script/src/ast/nodes/doc-tag.test.js +69 -0
  320. package/script/src/ast/nodes/doc.test.d.ts +2 -0
  321. package/script/src/ast/nodes/doc.test.d.ts.map +1 -0
  322. package/script/src/ast/nodes/doc.test.js +35 -0
  323. package/script/src/ast/nodes/enum-value.test.d.ts +2 -0
  324. package/script/src/ast/nodes/enum-value.test.d.ts.map +1 -0
  325. package/script/src/ast/nodes/enum-value.test.js +117 -0
  326. package/script/src/ast/nodes/enum.test.d.ts +2 -0
  327. package/script/src/ast/nodes/enum.test.d.ts.map +1 -0
  328. package/script/src/ast/nodes/enum.test.js +131 -0
  329. package/script/src/ast/nodes/function.test.d.ts +2 -0
  330. package/script/src/ast/nodes/function.test.d.ts.map +1 -0
  331. package/script/src/ast/nodes/function.test.js +162 -0
  332. package/script/src/ast/nodes/generic-parameter.test.d.ts +2 -0
  333. package/script/src/ast/nodes/generic-parameter.test.d.ts.map +1 -0
  334. package/script/src/ast/nodes/generic-parameter.test.js +51 -0
  335. package/script/src/ast/nodes/init-block.test.d.ts +2 -0
  336. package/script/src/ast/nodes/init-block.test.d.ts.map +1 -0
  337. package/script/src/ast/nodes/init-block.test.js +30 -0
  338. package/script/src/ast/nodes/interface.test.d.ts +2 -0
  339. package/script/src/ast/nodes/interface.test.d.ts.map +1 -0
  340. package/script/src/ast/nodes/interface.test.js +123 -0
  341. package/script/src/ast/nodes/object.test.d.ts +2 -0
  342. package/script/src/ast/nodes/object.test.d.ts.map +1 -0
  343. package/script/src/ast/nodes/object.test.js +80 -0
  344. package/script/src/ast/nodes/parameter.test.d.ts +2 -0
  345. package/script/src/ast/nodes/parameter.test.d.ts.map +1 -0
  346. package/script/src/ast/nodes/parameter.test.js +154 -0
  347. package/script/src/ast/nodes/property.test.d.ts +2 -0
  348. package/script/src/ast/nodes/property.test.d.ts.map +1 -0
  349. package/script/src/ast/nodes/property.test.js +208 -0
  350. package/script/src/ast/nodes/reference.test.d.ts +2 -0
  351. package/script/src/ast/nodes/reference.test.d.ts.map +1 -0
  352. package/script/src/ast/nodes/reference.test.js +38 -0
  353. package/script/src/ast/nodes/string.test.d.ts +2 -0
  354. package/script/src/ast/nodes/string.test.d.ts.map +1 -0
  355. package/script/src/ast/nodes/string.test.js +50 -0
  356. package/script/src/generators/services/okhttp3-clients/okhttp3-client-generator.js +26 -26
  357. package/script/src/generators/services/spring-controllers/spring-controller-generator.d.ts.map +1 -1
  358. package/script/src/generators/services/spring-controllers/spring-controller-generator.js +11 -7
  359. package/script/src/import-collection.test.d.ts +2 -0
  360. package/script/src/import-collection.test.d.ts.map +1 -0
  361. package/script/src/import-collection.test.js +101 -0
  362. package/script/tests/openapi-models.test.d.ts +2 -0
  363. package/script/tests/openapi-models.test.d.ts.map +1 -0
  364. package/script/tests/openapi-models.test.js +48 -0
  365. package/src/_dnt.test_polyfills.ts +70 -0
  366. package/src/_dnt.test_shims.ts +64 -0
  367. package/src/deps/jsr.io/@std/assert/1.0.7/assertion_error.ts +31 -0
  368. package/src/deps/jsr.io/@std/assert/1.0.7/equal.ts +152 -0
  369. package/src/deps/jsr.io/@std/assert/1.0.7/equals.ts +52 -0
  370. package/src/deps/jsr.io/@std/assert/1.0.7/false.ts +26 -0
  371. package/src/deps/jsr.io/@std/assert/1.0.7/instance_of.ts +64 -0
  372. package/src/deps/jsr.io/@std/assert/1.0.7/is_error.ts +65 -0
  373. package/src/deps/jsr.io/@std/assert/1.0.7/match.ts +30 -0
  374. package/src/deps/jsr.io/@std/assert/1.0.7/not_instance_of.ts +33 -0
  375. package/src/deps/jsr.io/@std/assert/1.0.7/not_match.ts +30 -0
  376. package/src/deps/jsr.io/@std/assert/1.0.7/not_strict_equals.ts +42 -0
  377. package/src/deps/jsr.io/@std/assert/1.0.7/rejects.ts +123 -0
  378. package/src/deps/jsr.io/@std/assert/1.0.7/strict_equals.ts +67 -0
  379. package/src/deps/jsr.io/@std/expect/1.0.7/_assert_equals.ts +38 -0
  380. package/src/deps/jsr.io/@std/expect/1.0.7/_assert_not_equals.ts +35 -0
  381. package/src/deps/jsr.io/@std/expect/1.0.7/_assertions.ts +18 -0
  382. package/src/deps/jsr.io/@std/expect/1.0.7/_asymmetric_matchers.ts +193 -0
  383. package/src/deps/jsr.io/@std/expect/1.0.7/_build_message.ts +51 -0
  384. package/src/deps/jsr.io/@std/expect/1.0.7/_custom_equality_tester.ts +19 -0
  385. package/src/deps/jsr.io/@std/expect/1.0.7/_equal.ts +230 -0
  386. package/src/deps/jsr.io/@std/expect/1.0.7/_extend.ts +16 -0
  387. package/src/deps/jsr.io/@std/expect/1.0.7/_inspect_args.ts +15 -0
  388. package/src/deps/jsr.io/@std/expect/1.0.7/_matchers.ts +832 -0
  389. package/src/deps/jsr.io/@std/expect/1.0.7/_mock_util.ts +22 -0
  390. package/src/deps/jsr.io/@std/expect/1.0.7/_types.ts +917 -0
  391. package/src/deps/jsr.io/@std/expect/1.0.7/_utils.ts +283 -0
  392. package/src/deps/jsr.io/@std/expect/1.0.7/expect.ts +601 -0
  393. package/src/deps/jsr.io/@std/internal/1.0.5/assertion_state.ts +214 -0
  394. package/src/deps/jsr.io/@std/internal/1.0.5/build_message.ts +134 -0
  395. package/src/deps/jsr.io/@std/internal/1.0.5/diff.ts +317 -0
  396. package/src/deps/jsr.io/@std/internal/1.0.5/diff_str.ts +204 -0
  397. package/src/deps/jsr.io/@std/internal/1.0.5/format.ts +39 -0
  398. package/src/deps/jsr.io/@std/internal/1.0.5/styles.ts +233 -0
  399. package/src/deps/jsr.io/@std/internal/1.0.5/types.ts +18 -0
  400. package/src/deps/jsr.io/@std/testing/1.0.4/_mock_utils.ts +43 -0
  401. package/src/deps/jsr.io/@std/testing/1.0.4/_test_suite.ts +410 -0
  402. package/src/deps/jsr.io/@std/testing/1.0.4/bdd.ts +1211 -0
  403. package/src/deps/jsr.io/@std/testing/1.0.4/mock.ts +1807 -0
  404. package/src/mod.ts +8 -0
  405. package/src/src/assets.ts +9 -0
  406. package/src/src/ast/_index.ts +66 -0
  407. package/src/src/ast/common.ts +1 -0
  408. package/src/src/ast/index.ts +1 -0
  409. package/src/src/ast/node.ts +10 -0
  410. package/src/src/ast/nodes/annotation.test.ts +69 -0
  411. package/src/src/ast/nodes/annotation.ts +79 -0
  412. package/src/src/ast/nodes/argument.test.ts +41 -0
  413. package/src/src/ast/nodes/argument.ts +62 -0
  414. package/src/src/ast/nodes/call.test.ts +44 -0
  415. package/src/src/ast/nodes/call.ts +66 -0
  416. package/src/src/ast/nodes/class.test.ts +274 -0
  417. package/src/src/ast/nodes/class.ts +178 -0
  418. package/src/src/ast/nodes/collection-literal.ts +49 -0
  419. package/src/src/ast/nodes/constructor.test.ts +178 -0
  420. package/src/src/ast/nodes/constructor.ts +126 -0
  421. package/src/src/ast/nodes/doc-tag.test.ts +84 -0
  422. package/src/src/ast/nodes/doc-tag.ts +138 -0
  423. package/src/src/ast/nodes/doc.test.ts +42 -0
  424. package/src/src/ast/nodes/doc.ts +111 -0
  425. package/src/src/ast/nodes/enum-value.test.ts +146 -0
  426. package/src/src/ast/nodes/enum-value.ts +100 -0
  427. package/src/src/ast/nodes/enum.test.ts +167 -0
  428. package/src/src/ast/nodes/enum.ts +163 -0
  429. package/src/src/ast/nodes/function.test.ts +194 -0
  430. package/src/src/ast/nodes/function.ts +176 -0
  431. package/src/src/ast/nodes/generic-parameter.test.ts +60 -0
  432. package/src/src/ast/nodes/generic-parameter.ts +54 -0
  433. package/src/src/ast/nodes/init-block.test.ts +36 -0
  434. package/src/src/ast/nodes/init-block.ts +38 -0
  435. package/src/src/ast/nodes/interface.test.ts +151 -0
  436. package/src/src/ast/nodes/interface.ts +133 -0
  437. package/src/src/ast/nodes/lambda-type.ts +68 -0
  438. package/src/src/ast/nodes/lambda.ts +68 -0
  439. package/src/src/ast/nodes/object.test.ts +101 -0
  440. package/src/src/ast/nodes/object.ts +102 -0
  441. package/src/src/ast/nodes/parameter.test.ts +191 -0
  442. package/src/src/ast/nodes/parameter.ts +118 -0
  443. package/src/src/ast/nodes/property.test.ts +253 -0
  444. package/src/src/ast/nodes/property.ts +225 -0
  445. package/src/src/ast/nodes/reference.test.ts +47 -0
  446. package/src/src/ast/nodes/reference.ts +178 -0
  447. package/src/src/ast/nodes/string.test.ts +61 -0
  448. package/src/src/ast/nodes/string.ts +114 -0
  449. package/src/src/ast/nodes/types.ts +23 -0
  450. package/src/src/ast/references/index.ts +8 -0
  451. package/src/src/ast/references/jackson.ts +16 -0
  452. package/src/src/ast/references/jakarta.ts +10 -0
  453. package/src/src/ast/references/java.ts +19 -0
  454. package/src/src/ast/references/kotlin.ts +40 -0
  455. package/src/src/ast/references/okhttp3.ts +5 -0
  456. package/src/src/ast/references/reactor.ts +5 -0
  457. package/src/src/ast/references/spring.ts +58 -0
  458. package/src/src/ast/references/swagger.ts +19 -0
  459. package/src/src/ast/utils/get-kotlin-builder-options.ts +19 -0
  460. package/src/src/ast/utils/to-kt-node.ts +31 -0
  461. package/src/src/ast/utils/write-kt-annotations.ts +15 -0
  462. package/src/src/ast/utils/write-kt-arguments.ts +45 -0
  463. package/src/src/ast/utils/write-kt-enum-values.ts +27 -0
  464. package/src/src/ast/utils/write-kt-generic-parameters.ts +12 -0
  465. package/src/src/ast/utils/write-kt-members.ts +25 -0
  466. package/src/src/ast/utils/write-kt-node.ts +37 -0
  467. package/src/src/ast/utils/write-kt-parameters.ts +25 -0
  468. package/src/src/common-results.ts +4 -0
  469. package/src/src/config.ts +39 -0
  470. package/src/src/file-builder.ts +108 -0
  471. package/src/src/generators/file-generator.ts +29 -0
  472. package/src/src/generators/index.ts +4 -0
  473. package/src/src/generators/models/args.ts +128 -0
  474. package/src/src/generators/models/index.ts +4 -0
  475. package/src/src/generators/models/model-generator.ts +602 -0
  476. package/src/src/generators/models/models-generator.ts +65 -0
  477. package/src/src/generators/models/models.ts +95 -0
  478. package/src/src/generators/services/okhttp3-clients/args.ts +78 -0
  479. package/src/src/generators/services/okhttp3-clients/index.ts +4 -0
  480. package/src/src/generators/services/okhttp3-clients/models.ts +60 -0
  481. package/src/src/generators/services/okhttp3-clients/okhttp3-client-generator.ts +557 -0
  482. package/src/src/generators/services/okhttp3-clients/okhttp3-clients-generator.ts +128 -0
  483. package/src/src/generators/services/okhttp3-clients/refs.ts +55 -0
  484. package/src/src/generators/services/spring-controllers/args.ts +71 -0
  485. package/src/src/generators/services/spring-controllers/index.ts +4 -0
  486. package/src/src/generators/services/spring-controllers/models.ts +58 -0
  487. package/src/src/generators/services/spring-controllers/spring-controller-generator.ts +609 -0
  488. package/src/src/generators/services/spring-controllers/spring-controllers-generator.ts +70 -0
  489. package/src/src/import-collection.test.ts +116 -0
  490. package/src/src/import-collection.ts +98 -0
  491. package/src/src/types.ts +3 -0
  492. package/src/src/utils.ts +39 -0
  493. package/src/tests/openapi-models.test.ts +63 -0
  494. package/test_runner.js +227 -0
@@ -0,0 +1,557 @@
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) => x.name),
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) => x.name),
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 result = appendValueGroup<Builder>([], '\n');
313
+
314
+ if (endpoint.requestBody) {
315
+ if (endpoint.requestBody.content[0]?.type === 'multipart/form-data') {
316
+ const partConfigs = parameters
317
+ .filter((x) => x.multipart)
318
+ .map<KtValue<Builder>>((param) => {
319
+ const paramName = toCasing(param.name, ctx.config.parameterNameCasing);
320
+ return s`"${param.multipart?.name ?? ''}" to ${ctx.refs.partConfig.infer()}(body = ${paramName})`;
321
+ });
322
+ result.values.push(
323
+ s`val localVariableBody = ${
324
+ kt.call(kt.refs.mapOf([kt.refs.string(), ctx.refs.partConfig(['*'])]), partConfigs)
325
+ }`,
326
+ );
327
+ } else {
328
+ const bodyParamName = toCasing(this.getRequestBodyParamName(ctx, { endpoint }), ctx.config.parameterNameCasing);
329
+ result.values.push(`val localVariableBody = ${bodyParamName}`);
330
+ }
331
+ }
332
+
333
+ result.values.push(
334
+ s`val localVariableQuery: ${ctx.refs.multiValueMap()} = ${
335
+ kt.call(
336
+ [kt.refs.mutableMapOf([kt.refs.string(), kt.refs.list([kt.refs.string()])])],
337
+ [],
338
+ )
339
+ }${
340
+ queryParameters.length === 0 ? '' : s.indent`
341
+ .apply {${s.indent`
342
+ ${
343
+ appendValueGroup(
344
+ queryParameters.map((param) => {
345
+ const paramName = toCasing(param.name, ctx.config.parameterNameCasing);
346
+ const toString = param.schema?.kind === 'array' ? '.joinToString()' : '.toString()';
347
+ const put = s<Builder>`put(${kt.string(paramName)}, listOf(${paramName}${toString}))`;
348
+ return param.required ? put : s<Builder>`if (${paramName} != null) {${s.indent`
349
+ ${put}`}
350
+ }`;
351
+ }),
352
+ '\n',
353
+ )
354
+ }`}
355
+ }`
356
+ }`,
357
+ );
358
+
359
+ result.values.push('val localVariableHeaders: MutableMap<String, String> = mutableMapOf()');
360
+ if (endpoint.requestBody?.content[0] !== undefined) {
361
+ result.values.push(`localVariableHeaders["Content-Type"] = "${endpoint.requestBody?.content[0].type}"`);
362
+ }
363
+
364
+ result.values.push(
365
+ s`return ${
366
+ kt.call(
367
+ [ctx.refs.requestConfig.infer()],
368
+ [
369
+ kt.argument.named('method', kt.call([ctx.refs.requestMethod(), endpoint.method.toUpperCase()])),
370
+ kt.argument.named('path', kt.string(this.getPathWithInterpolation(ctx, { endpoint }), { template: true })),
371
+ kt.argument.named('query', 'localVariableQuery'),
372
+ kt.argument.named('headers', 'localVariableHeaders'),
373
+ kt.argument.named('requiresAuthentication', 'false'),
374
+ endpoint.requestBody ? kt.argument.named('body', 'localVariableBody') : null,
375
+ ],
376
+ )
377
+ }`,
378
+ );
379
+
380
+ return result;
381
+ }
382
+
383
+ protected getAdditionalClientMembers(
384
+ _ctx: Context,
385
+ _args: Args.GetAdditionalClientMembers,
386
+ ): kt.ClassMember<Builder>[] {
387
+ return [
388
+ kt.function('encodeURIComponent', {
389
+ accessModifier: 'private',
390
+ parameters: [kt.parameter('uriComponent', kt.refs.string())],
391
+ returnType: kt.refs.string(),
392
+ singleExpression: true,
393
+ body:
394
+ s`${kt.refs.okhttp3.httpUrl()}.Builder().scheme("http").host("localhost").addPathSegment(uriComponent).build().encodedPathSegments[0]`,
395
+ }),
396
+ ];
397
+ }
398
+
399
+ protected getParameterType(ctx: Context, args: Args.GetParameterType): kt.Type<Builder> {
400
+ const { parameter } = args;
401
+ if (parameter.multipart?.isFile) {
402
+ return kt.refs.java.file();
403
+ }
404
+ return this.getTypeUsage(ctx, {
405
+ schema: parameter.schema,
406
+ nullable: !parameter.required,
407
+ });
408
+ }
409
+
410
+ protected getRequestBodyType(ctx: Context, args: Args.GetRequestBodyType): kt.Type<Builder> {
411
+ const { endpoint } = args;
412
+ const content = endpoint.requestBody?.content[0];
413
+ return content?.type === 'multipart/form-data'
414
+ ? kt.refs.map([kt.refs.string(), ctx.refs.partConfig(['*'])])
415
+ : this.getTypeUsage(ctx, { schema: content?.schema, fallback: kt.refs.unit() });
416
+ }
417
+
418
+ protected getTypeUsage(ctx: Context, args: Args.GetTypeUsage<Builder>): kt.Type<Builder> {
419
+ const { schema, nullable, fallback } = args;
420
+ const type = this.getSchemaType(ctx, { schema });
421
+ return type
422
+ ? createOverwriteProxy(type, { nullable: nullable ?? type.nullable })
423
+ : (fallback ?? kt.refs.any({ nullable }));
424
+ }
425
+
426
+ protected getPackageName(ctx: Context, _args: Args.GetPackageName): string {
427
+ const packageSuffix = typeof ctx.config.packageSuffix === 'string'
428
+ ? ctx.config.packageSuffix
429
+ : ctx.config.packageSuffix(ctx.service);
430
+ return ctx.config.packageName + packageSuffix;
431
+ }
432
+
433
+ protected getPathWithInterpolation(ctx: Context, args: Args.GetPathWithInterpolation): string {
434
+ const { endpoint } = args;
435
+ let path = this.getEndpointPath(ctx, { endpoint });
436
+ endpoint.parameters
437
+ .filter((x) => x.target === 'path')
438
+ .forEach((parameter) => {
439
+ path = path.replace(
440
+ `{${parameter.name}}`,
441
+ `\${encodeURIComponent(${toCasing(parameter.name, 'camel')}.toString())}`,
442
+ );
443
+ });
444
+ return path;
445
+ }
446
+
447
+ protected getResponseSchema(_ctx: Context, args: Args.GetResponseSchema): ApiSchema | undefined {
448
+ const { endpoint } = args;
449
+ return endpoint.responses.find((x) => !x.statusCode || (x.statusCode >= 200 && x.statusCode < 300))
450
+ ?.contentOptions[0]?.schema;
451
+ }
452
+
453
+ protected getSchemaType(ctx: Context, args: Args.GetSchemaType): kt.Reference<SourceBuilder> | undefined {
454
+ const { schema } = args;
455
+ return schema && ctx.input.kotlin.models[schema.id].type;
456
+ }
457
+
458
+ protected getAllParameters(ctx: Context, args: Args.GetAllParameters): ApiParameterWithMultipartInfo[] {
459
+ const { endpoint } = args;
460
+ const parameters = endpoint.parameters.filter(
461
+ (parameter) => parameter.target === 'query' || parameter.target === 'path',
462
+ );
463
+ if (endpoint.requestBody) {
464
+ const content = endpoint.requestBody.content[0];
465
+ let schema = content.schema;
466
+
467
+ if (content.type === 'multipart/form-data') {
468
+ if (schema && schema.kind === 'object') {
469
+ schema = resolveAnyOfAndAllOf(schema, true) ?? schema;
470
+ const properties = schema.properties ?? {};
471
+ for (const [name, property] of properties.entries()) {
472
+ parameters.push(
473
+ Object.assign(
474
+ this.createApiParameter({
475
+ id: `multipart-${name}`,
476
+ name,
477
+ target: 'body',
478
+ schema: property.schema,
479
+ required: schema.required.has(name),
480
+ description: property.schema.description,
481
+ }),
482
+ {
483
+ multipart: {
484
+ name,
485
+ isFile: property.schema.kind === 'string' && property.schema.format === 'binary',
486
+ },
487
+ },
488
+ ),
489
+ );
490
+ }
491
+ }
492
+ } else {
493
+ parameters.push(
494
+ this.createApiParameter({
495
+ id: 'body',
496
+ name: this.getRequestBodyParamName(ctx, { endpoint }),
497
+ target: 'body',
498
+ schema,
499
+ required: endpoint.requestBody.required,
500
+ description: endpoint.requestBody.description,
501
+ }),
502
+ );
503
+ }
504
+ }
505
+
506
+ return parameters.sort((a, b) => (a.required === b.required ? 0 : a.required ? -1 : 1));
507
+ }
508
+
509
+ protected getRequestBodyParamName(ctx: Context, args: Args.GetRequestBodyParamName): string {
510
+ const { endpoint } = args;
511
+ const schema = endpoint.requestBody?.content[0].schema;
512
+ const schemaInfo = this.getSchemaType(ctx, { schema });
513
+ return toCasing(
514
+ schemaInfo && schemaInfo.name !== 'Any' ? SourceBuilder.build((b) => kt.reference.write(b, schemaInfo)) : 'body',
515
+ ctx.config.parameterNameCasing,
516
+ );
517
+ }
518
+
519
+ protected getBasePath(ctx: Context, _args: Args.GetBasePath): string {
520
+ return modifyString(
521
+ (ctx.service.$src ?? ctx.service.endpoints[0]?.$src)?.document.servers?.[0]?.url ?? '/',
522
+ ctx.config.basePath,
523
+ ctx.service,
524
+ );
525
+ }
526
+
527
+ protected getEndpointPath(ctx: Context, args: Args.GetEndpointPath): string {
528
+ const { endpoint } = args;
529
+ return modifyString(endpoint.path, ctx.config.pathModifier, endpoint);
530
+ }
531
+
532
+ protected getFilePath(ctx: Context, args: Args.GetFilePath): string {
533
+ const { packageName } = args;
534
+ return `${ctx.config.outputDir}/${packageName.replace(/\./g, '/')}/${this.getApiClientName(ctx, {})}.kt`;
535
+ }
536
+
537
+ protected getApiClientName(ctx: Context, _args: Args.GetApiClientName): string {
538
+ return toCasing(ctx.service.name, ctx.config.typeNameCasing) + 'ApiClient';
539
+ }
540
+
541
+ private createApiParameter(data: Partial<ApiParameter> & Pick<ApiParameter, 'id' | 'name' | 'target'>): ApiParameter {
542
+ return {
543
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
544
+ $src: undefined!,
545
+ $ref: undefined,
546
+ schema: undefined,
547
+ required: false,
548
+ description: undefined,
549
+ allowEmptyValue: undefined,
550
+ allowReserved: undefined,
551
+ deprecated: false,
552
+ explode: undefined,
553
+ style: undefined,
554
+ ...data,
555
+ };
556
+ }
557
+ }
@@ -0,0 +1,128 @@
1
+ import { resolve } from 'node:path';
2
+
3
+
4
+ import fs from 'fs-extra';
5
+
6
+ import {
7
+ type ApiService,
8
+ Factory,
9
+ type MaybePromise,
10
+ type OpenApiGeneratorContext,
11
+ OpenApiServicesGenerationProviderBase,
12
+ } from '@goast/core';
13
+
14
+ import { getAssetFileContent } from '../../../assets.js';
15
+ import type { KotlinServicesGeneratorInput } from '../spring-controllers/index.js';
16
+ import {
17
+ defaultKotlinOkHttp3ClientsGeneratorConfig,
18
+ type KotlinOkHttp3ClientGeneratorOutput,
19
+ type KotlinOkHttp3ClientsGeneratorConfig,
20
+ type KotlinOkHttp3ClientsGeneratorContext,
21
+ type KotlinOkHttp3ClientsGeneratorInput,
22
+ type KotlinOkHttp3ClientsGeneratorOutput,
23
+ } from './models.js';
24
+ import { DefaultKotlinOkHttp3Generator, type KotlinOkHttp3Generator } from './okhttp3-client-generator.js';
25
+ import { getReferenceFactories } from './refs.js';
26
+
27
+ type Input = KotlinOkHttp3ClientsGeneratorInput;
28
+ type Output = KotlinOkHttp3ClientsGeneratorOutput;
29
+ type Config = KotlinOkHttp3ClientsGeneratorConfig;
30
+ type ServiceOutput = KotlinOkHttp3ClientGeneratorOutput;
31
+ type Context = KotlinOkHttp3ClientsGeneratorContext;
32
+
33
+ export class KotlinOkHttp3ClientsGenerator extends OpenApiServicesGenerationProviderBase<
34
+ Input,
35
+ Output,
36
+ Config,
37
+ ServiceOutput,
38
+ Context
39
+ > {
40
+ private readonly _serviceGeneratorFactory: Factory<KotlinOkHttp3Generator, []>;
41
+
42
+ constructor(serviceGeneratorFactory?: Factory<KotlinOkHttp3Generator, []>) {
43
+ super();
44
+ this._serviceGeneratorFactory = serviceGeneratorFactory ?? Factory.fromValue(new DefaultKotlinOkHttp3Generator());
45
+ }
46
+
47
+ protected override async generateAdditionalFiles(ctx: KotlinOkHttp3ClientsGeneratorContext): Promise<void> {
48
+ await this.copyInfrastructureFiles(ctx);
49
+ }
50
+
51
+ protected initResult(): Output {
52
+ return {
53
+ kotlin: {
54
+ clients: {},
55
+ },
56
+ };
57
+ }
58
+
59
+ protected generateService(ctx: Context, service: ApiService): MaybePromise<ServiceOutput> {
60
+ const serviceGenerator = this._serviceGeneratorFactory.create();
61
+ return serviceGenerator.generate({
62
+ ...ctx,
63
+ service,
64
+ });
65
+ }
66
+
67
+ protected addServiceResult(ctx: Context, service: ApiService, result: ServiceOutput): void {
68
+ ctx.output.kotlin.clients[service.id] = result;
69
+ }
70
+
71
+ protected buildContext(
72
+ context: OpenApiGeneratorContext<KotlinServicesGeneratorInput>,
73
+ config?: Partial<Config> | undefined,
74
+ ): Context {
75
+ context.data.services = context.data.services.filter((x) => x.name !== 'exclude-from-generation');
76
+ const providerContext = this.getProviderContext(context, config, defaultKotlinOkHttp3ClientsGeneratorConfig);
77
+ const infrastructurePackageName = this.getInfrastructurePackageName(providerContext.config);
78
+ return Object.assign(providerContext, {
79
+ infrastructurePackageName,
80
+ refs: getReferenceFactories(infrastructurePackageName),
81
+ });
82
+ }
83
+
84
+ protected getInfrastructurePackageName(config: Config): string {
85
+ if (typeof config.infrastructurePackageName === 'string') {
86
+ return config.infrastructurePackageName;
87
+ }
88
+ if (config.infrastructurePackageName.mode === 'append-package-name') {
89
+ return config.packageName + config.infrastructurePackageName.value;
90
+ }
91
+ if (config.infrastructurePackageName.mode === 'append-full-package-name') {
92
+ return this.getPackageName(config) + config.infrastructurePackageName.value;
93
+ }
94
+
95
+ return config.infrastructurePackageName.value;
96
+ }
97
+
98
+ protected getPackageName(config: Config): string {
99
+ const packageSuffix = typeof config.packageSuffix === 'string' ? config.packageSuffix : config.packageSuffix();
100
+ return config.packageName + packageSuffix;
101
+ }
102
+
103
+ private async copyInfrastructureFiles(ctx: Context): Promise<void> {
104
+ const targetDir = resolve(ctx.config.outputDir, ctx.infrastructurePackageName.replace(/\./g, '/'));
105
+ await fs.ensureDir(targetDir);
106
+
107
+ const files = [
108
+ 'ApiAbstractions.kt',
109
+ 'ApiClient.kt',
110
+ 'ApiResponse.kt',
111
+ 'Errors.kt',
112
+ 'PartConfig.kt',
113
+ 'RequestConfig.kt',
114
+ 'RequestMethod.kt',
115
+ 'ResponseExtensions.kt',
116
+ 'Serializer.kt',
117
+ ];
118
+
119
+ for (const file of files) {
120
+ const sourcePath = `client/okhttp3/${file}`;
121
+ const targetPath = resolve(targetDir, file);
122
+ console.log(`Copying asset file "${sourcePath}" to "${targetPath}"`);
123
+ const fileContent = (await getAssetFileContent(sourcePath))
124
+ .replace(/@PACKAGE_NAME@/g, ctx.infrastructurePackageName);
125
+ fs.writeFileSync(targetPath, fileContent);
126
+ }
127
+ }
128
+ }