@mx-space/api-client 1.0.0-beta.2 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (508) hide show
  1. package/.eslintcache +1 -0
  2. package/__tests__/adaptors/axios.spec.ts +7 -0
  3. package/__tests__/adaptors/ky.spec.ts +9 -0
  4. package/__tests__/adaptors/umi-request.spec.ts +7 -0
  5. package/__tests__/contronllers/aggregate.test.ts +389 -0
  6. package/__tests__/contronllers/category.test.ts +284 -0
  7. package/__tests__/contronllers/comment.test.ts +113 -0
  8. package/__tests__/contronllers/link.test.ts +95 -0
  9. package/__tests__/contronllers/note.test.ts +120 -0
  10. package/__tests__/contronllers/page.test.ts +49 -0
  11. package/__tests__/contronllers/post.test.ts +77 -0
  12. package/__tests__/contronllers/recently.test.ts +49 -0
  13. package/__tests__/contronllers/say.test.ts +106 -0
  14. package/__tests__/contronllers/search.test.ts +81 -0
  15. package/__tests__/contronllers/serverless.test.ts +19 -0
  16. package/__tests__/contronllers/snippet.test.ts +38 -0
  17. package/__tests__/contronllers/topic.test.ts +17 -0
  18. package/__tests__/contronllers/user.test.ts +59 -0
  19. package/__tests__/core/client.test.ts +293 -0
  20. package/__tests__/helpers/adaptor-test.ts +108 -0
  21. package/__tests__/helpers/e2e-mock-server.ts +22 -0
  22. package/__tests__/helpers/global-fetch.ts +39 -0
  23. package/__tests__/helpers/instance.ts +11 -0
  24. package/__tests__/helpers/response.ts +76 -0
  25. package/__tests__/mock/algolia.json +446 -0
  26. package/__tests__/utils/auto-bind.spec.ts +27 -0
  27. package/__tests__/utils/camelcase-keys.spec.ts +86 -0
  28. package/__tests__/utils/index.test.ts +33 -0
  29. package/__tests__/utils/path.spec.ts +8 -0
  30. package/adaptors/axios.ts +44 -0
  31. package/adaptors/ky.ts +76 -0
  32. package/adaptors/umi-request.ts +38 -0
  33. package/controllers/aggregate.ts +6 -6
  34. package/controllers/base.ts +3 -3
  35. package/controllers/category.ts +7 -7
  36. package/controllers/comment.ts +8 -8
  37. package/controllers/link.ts +3 -3
  38. package/controllers/note.ts +15 -11
  39. package/controllers/page.ts +7 -7
  40. package/controllers/post.ts +9 -9
  41. package/controllers/project.ts +3 -3
  42. package/controllers/recently.ts +5 -5
  43. package/controllers/say.ts +5 -5
  44. package/controllers/search.ts +8 -8
  45. package/controllers/severless.ts +4 -4
  46. package/controllers/snippet.ts +4 -4
  47. package/controllers/topic.ts +5 -5
  48. package/controllers/user.ts +5 -5
  49. package/core/attach-request.ts +43 -0
  50. package/core/client.ts +252 -0
  51. package/core/error.ts +10 -0
  52. package/core/index.ts +2 -0
  53. package/coverage/lcov-report/__tests__/helpers/adaptor-test.ts.html +405 -0
  54. package/coverage/lcov-report/__tests__/helpers/e2e-mock-server.ts.html +150 -0
  55. package/coverage/lcov-report/__tests__/helpers/index.html +236 -0
  56. package/coverage/lcov-report/__tests__/helpers/instance.ts.html +120 -0
  57. package/coverage/lcov-report/__tests__/helpers/response.ts.html +231 -0
  58. package/dist/adaptors/axios.cjs.map +1 -1
  59. package/dist/adaptors/axios.d.ts +2 -2
  60. package/dist/adaptors/axios.js.map +1 -1
  61. package/dist/adaptors/axios.min.cjs.map +1 -1
  62. package/dist/adaptors/axios.min.js.map +1 -1
  63. package/dist/adaptors/axios.umd.js.map +1 -1
  64. package/dist/adaptors/axios.umd.min.js.map +1 -1
  65. package/dist/adaptors/ky.cjs.map +1 -1
  66. package/dist/adaptors/ky.d.ts +1 -1
  67. package/dist/adaptors/ky.js.map +1 -1
  68. package/dist/adaptors/ky.min.cjs +1 -1
  69. package/dist/adaptors/ky.min.cjs.map +1 -1
  70. package/dist/adaptors/ky.min.js +1 -1
  71. package/dist/adaptors/ky.min.js.map +1 -1
  72. package/dist/adaptors/ky.umd.js.map +1 -1
  73. package/dist/adaptors/ky.umd.min.js +1 -1
  74. package/dist/adaptors/ky.umd.min.js.map +1 -1
  75. package/dist/adaptors/umi-request.cjs.map +1 -1
  76. package/dist/adaptors/umi-request.d.ts +2 -2
  77. package/dist/adaptors/umi-request.js.map +1 -1
  78. package/dist/adaptors/umi-request.min.cjs.map +1 -1
  79. package/dist/adaptors/umi-request.min.js.map +1 -1
  80. package/dist/adaptors/umi-request.umd.js.map +1 -1
  81. package/dist/adaptors/umi-request.umd.min.js.map +1 -1
  82. package/dist/index.cjs.map +1 -1
  83. package/dist/index.js.map +1 -1
  84. package/dist/index.min.cjs.map +1 -1
  85. package/dist/index.min.js.map +1 -1
  86. package/dist/index.umd.js.map +1 -1
  87. package/dist/index.umd.min.js.map +1 -1
  88. package/index.ts +1 -0
  89. package/interfaces/adapter.ts +1 -1
  90. package/interfaces/client.ts +2 -2
  91. package/interfaces/request.ts +1 -1
  92. package/models/aggregate.ts +7 -7
  93. package/models/base.ts +4 -0
  94. package/models/category.ts +2 -2
  95. package/models/comment.ts +2 -2
  96. package/models/link.ts +1 -1
  97. package/models/note.ts +8 -2
  98. package/models/page.ts +1 -1
  99. package/models/post.ts +2 -2
  100. package/models/project.ts +1 -1
  101. package/models/recently.ts +5 -10
  102. package/models/say.ts +1 -1
  103. package/models/snippet.ts +1 -1
  104. package/models/topic.ts +1 -1
  105. package/models/user.ts +1 -1
  106. package/package.json +9 -29
  107. package/rollup.config.js +150 -0
  108. package/utils/auto-bind.ts +48 -0
  109. package/utils/camelcase-keys.ts +26 -0
  110. package/utils/index.ts +53 -0
  111. package/utils/path.ts +6 -0
  112. package/build/index.cjs.js +0 -980
  113. package/build/index.cjs.js.map +0 -1
  114. package/build/index.cjs.min.js +0 -2
  115. package/build/index.cjs.min.js.map +0 -1
  116. package/build/index.esm.min.mjs +0 -2
  117. package/build/index.esm.min.mjs.map +0 -1
  118. package/build/index.esm.mjs +0 -958
  119. package/build/index.esm.mjs.map +0 -1
  120. package/build/index.umd.js +0 -986
  121. package/build/index.umd.js.map +0 -1
  122. package/build/index.umd.min.js +0 -2
  123. package/build/index.umd.min.js.map +0 -1
  124. package/esm/adaptors/axios.d.ts +0 -4
  125. package/esm/adaptors/axios.js +0 -36
  126. package/esm/adaptors/axios.js.map +0 -1
  127. package/esm/adaptors/ky.d.ts +0 -23
  128. package/esm/adaptors/ky.js +0 -61
  129. package/esm/adaptors/ky.js.map +0 -1
  130. package/esm/adaptors/umi-request.d.ts +0 -4
  131. package/esm/adaptors/umi-request.js +0 -30
  132. package/esm/adaptors/umi-request.js.map +0 -1
  133. package/esm/controllers/aggregate.d.ts +0 -64
  134. package/esm/controllers/aggregate.js +0 -42
  135. package/esm/controllers/aggregate.js.map +0 -1
  136. package/esm/controllers/base.d.ts +0 -43
  137. package/esm/controllers/base.js +0 -27
  138. package/esm/controllers/base.js.map +0 -1
  139. package/esm/controllers/category.d.ts +0 -115
  140. package/esm/controllers/category.js +0 -68
  141. package/esm/controllers/category.js.map +0 -1
  142. package/esm/controllers/comment.d.ts +0 -81
  143. package/esm/controllers/comment.js +0 -47
  144. package/esm/controllers/comment.js.map +0 -1
  145. package/esm/controllers/index.d.ts +0 -18
  146. package/esm/controllers/index.js +0 -55
  147. package/esm/controllers/index.js.map +0 -1
  148. package/esm/controllers/link.d.ts +0 -20
  149. package/esm/controllers/link.js +0 -21
  150. package/esm/controllers/link.js.map +0 -1
  151. package/esm/controllers/note.d.ts +0 -103
  152. package/esm/controllers/note.js +0 -68
  153. package/esm/controllers/note.js.map +0 -1
  154. package/esm/controllers/page.d.ts +0 -59
  155. package/esm/controllers/page.js +0 -42
  156. package/esm/controllers/page.js.map +0 -1
  157. package/esm/controllers/post.d.ts +0 -72
  158. package/esm/controllers/post.js +0 -52
  159. package/esm/controllers/post.js.map +0 -1
  160. package/esm/controllers/project.d.ts +0 -15
  161. package/esm/controllers/project.js +0 -12
  162. package/esm/controllers/project.js.map +0 -1
  163. package/esm/controllers/recently.d.ts +0 -61
  164. package/esm/controllers/recently.js +0 -31
  165. package/esm/controllers/recently.js.map +0 -1
  166. package/esm/controllers/say.d.ts +0 -37
  167. package/esm/controllers/say.js +0 -21
  168. package/esm/controllers/say.js.map +0 -1
  169. package/esm/controllers/search.d.ts +0 -247
  170. package/esm/controllers/search.js +0 -28
  171. package/esm/controllers/search.js.map +0 -1
  172. package/esm/controllers/severless.d.ts +0 -24
  173. package/esm/controllers/severless.js +0 -16
  174. package/esm/controllers/severless.js.map +0 -1
  175. package/esm/controllers/snippet.d.ts +0 -24
  176. package/esm/controllers/snippet.js +0 -19
  177. package/esm/controllers/snippet.js.map +0 -1
  178. package/esm/controllers/topic.d.ts +0 -26
  179. package/esm/controllers/topic.js +0 -18
  180. package/esm/controllers/topic.js.map +0 -1
  181. package/esm/controllers/user.d.ts +0 -70
  182. package/esm/controllers/user.js +0 -40
  183. package/esm/controllers/user.js.map +0 -1
  184. package/esm/core/attach-request.d.ts +0 -2
  185. package/esm/core/attach-request.js +0 -36
  186. package/esm/core/attach-request.js.map +0 -1
  187. package/esm/core/client.d.ts +0 -29
  188. package/esm/core/client.js +0 -186
  189. package/esm/core/client.js.map +0 -1
  190. package/esm/core/error.d.ts +0 -6
  191. package/esm/core/error.js +0 -9
  192. package/esm/core/error.js.map +0 -1
  193. package/esm/core/index.d.ts +0 -2
  194. package/esm/core/index.js +0 -3
  195. package/esm/core/index.js.map +0 -1
  196. package/esm/dtos/comment.d.ts +0 -6
  197. package/esm/dtos/comment.js +0 -3
  198. package/esm/dtos/comment.js.map +0 -1
  199. package/esm/index.d.ts +0 -7
  200. package/esm/index.js +0 -7
  201. package/esm/index.js.map +0 -1
  202. package/esm/interfaces/adapter.d.ts +0 -14
  203. package/esm/interfaces/adapter.js +0 -2
  204. package/esm/interfaces/adapter.js.map +0 -1
  205. package/esm/interfaces/client.d.ts +0 -13
  206. package/esm/interfaces/client.js +0 -2
  207. package/esm/interfaces/client.js.map +0 -1
  208. package/esm/interfaces/controller.d.ts +0 -4
  209. package/esm/interfaces/controller.js +0 -2
  210. package/esm/interfaces/controller.js.map +0 -1
  211. package/esm/interfaces/instance.d.ts +0 -7
  212. package/esm/interfaces/instance.js +0 -2
  213. package/esm/interfaces/instance.js.map +0 -1
  214. package/esm/interfaces/options.d.ts +0 -1
  215. package/esm/interfaces/options.js +0 -2
  216. package/esm/interfaces/options.js.map +0 -1
  217. package/esm/interfaces/params.d.ts +0 -4
  218. package/esm/interfaces/params.js +0 -2
  219. package/esm/interfaces/params.js.map +0 -1
  220. package/esm/interfaces/request.d.ts +0 -43
  221. package/esm/interfaces/request.js +0 -2
  222. package/esm/interfaces/request.js.map +0 -1
  223. package/esm/interfaces/types.d.ts +0 -2
  224. package/esm/interfaces/types.js +0 -2
  225. package/esm/interfaces/types.js.map +0 -1
  226. package/esm/models/aggregate.d.ts +0 -53
  227. package/esm/models/aggregate.js +0 -6
  228. package/esm/models/aggregate.js.map +0 -1
  229. package/esm/models/base.d.ts +0 -38
  230. package/esm/models/base.js +0 -2
  231. package/esm/models/base.js.map +0 -1
  232. package/esm/models/category.d.ts +0 -22
  233. package/esm/models/category.js +0 -6
  234. package/esm/models/category.js.map +0 -1
  235. package/esm/models/comment.d.ts +0 -37
  236. package/esm/models/comment.js +0 -13
  237. package/esm/models/comment.js.map +0 -1
  238. package/esm/models/index.d.ts +0 -14
  239. package/esm/models/index.js +0 -15
  240. package/esm/models/index.js.map +0 -1
  241. package/esm/models/link.d.ts +0 -22
  242. package/esm/models/link.js +0 -14
  243. package/esm/models/link.js.map +0 -1
  244. package/esm/models/note.d.ts +0 -33
  245. package/esm/models/note.js +0 -2
  246. package/esm/models/note.js.map +0 -1
  247. package/esm/models/page.d.ts +0 -14
  248. package/esm/models/page.js +0 -7
  249. package/esm/models/page.js.map +0 -1
  250. package/esm/models/post.d.ts +0 -17
  251. package/esm/models/post.js +0 -2
  252. package/esm/models/post.js.map +0 -1
  253. package/esm/models/project.d.ts +0 -11
  254. package/esm/models/project.js +0 -2
  255. package/esm/models/project.js.map +0 -1
  256. package/esm/models/recently.d.ts +0 -26
  257. package/esm/models/recently.js +0 -7
  258. package/esm/models/recently.js.map +0 -1
  259. package/esm/models/say.d.ts +0 -6
  260. package/esm/models/say.js +0 -2
  261. package/esm/models/say.js.map +0 -1
  262. package/esm/models/setting.d.ts +0 -66
  263. package/esm/models/setting.js +0 -2
  264. package/esm/models/setting.js.map +0 -1
  265. package/esm/models/snippet.d.ts +0 -18
  266. package/esm/models/snippet.js +0 -8
  267. package/esm/models/snippet.js.map +0 -1
  268. package/esm/models/topic.d.ts +0 -8
  269. package/esm/models/topic.js +0 -2
  270. package/esm/models/topic.js.map +0 -1
  271. package/esm/models/user.d.ts +0 -21
  272. package/esm/models/user.js +0 -2
  273. package/esm/models/user.js.map +0 -1
  274. package/esm/utils/auto-bind.d.ts +0 -4
  275. package/esm/utils/auto-bind.js +0 -36
  276. package/esm/utils/auto-bind.js.map +0 -1
  277. package/esm/utils/camelcase-keys.d.ts +0 -6
  278. package/esm/utils/camelcase-keys.js +0 -23
  279. package/esm/utils/camelcase-keys.js.map +0 -1
  280. package/esm/utils/index.d.ts +0 -5
  281. package/esm/utils/index.js +0 -43
  282. package/esm/utils/index.js.map +0 -1
  283. package/esm/utils/path.d.ts +0 -1
  284. package/esm/utils/path.js +0 -7
  285. package/esm/utils/path.js.map +0 -1
  286. package/esm/vitest.config.d.ts +0 -2
  287. package/esm/vitest.config.js +0 -12
  288. package/esm/vitest.config.js.map +0 -1
  289. package/lib/adaptors/axios.d.ts +0 -4
  290. package/lib/adaptors/axios.js +0 -42
  291. package/lib/adaptors/axios.js.map +0 -1
  292. package/lib/adaptors/ky.d.ts +0 -23
  293. package/lib/adaptors/ky.js +0 -68
  294. package/lib/adaptors/ky.js.map +0 -1
  295. package/lib/adaptors/umi-request.d.ts +0 -4
  296. package/lib/adaptors/umi-request.js +0 -33
  297. package/lib/adaptors/umi-request.js.map +0 -1
  298. package/lib/controllers/aggregate.d.ts +0 -64
  299. package/lib/controllers/aggregate.js +0 -46
  300. package/lib/controllers/aggregate.js.map +0 -1
  301. package/lib/controllers/base.d.ts +0 -43
  302. package/lib/controllers/base.js +0 -31
  303. package/lib/controllers/base.js.map +0 -1
  304. package/lib/controllers/category.d.ts +0 -115
  305. package/lib/controllers/category.js +0 -72
  306. package/lib/controllers/category.js.map +0 -1
  307. package/lib/controllers/comment.d.ts +0 -81
  308. package/lib/controllers/comment.js +0 -51
  309. package/lib/controllers/comment.js.map +0 -1
  310. package/lib/controllers/index.d.ts +0 -18
  311. package/lib/controllers/index.js +0 -72
  312. package/lib/controllers/index.js.map +0 -1
  313. package/lib/controllers/link.d.ts +0 -20
  314. package/lib/controllers/link.js +0 -25
  315. package/lib/controllers/link.js.map +0 -1
  316. package/lib/controllers/note.d.ts +0 -103
  317. package/lib/controllers/note.js +0 -72
  318. package/lib/controllers/note.js.map +0 -1
  319. package/lib/controllers/page.d.ts +0 -59
  320. package/lib/controllers/page.js +0 -46
  321. package/lib/controllers/page.js.map +0 -1
  322. package/lib/controllers/post.d.ts +0 -72
  323. package/lib/controllers/post.js +0 -56
  324. package/lib/controllers/post.js.map +0 -1
  325. package/lib/controllers/project.d.ts +0 -15
  326. package/lib/controllers/project.js +0 -16
  327. package/lib/controllers/project.js.map +0 -1
  328. package/lib/controllers/recently.d.ts +0 -61
  329. package/lib/controllers/recently.js +0 -35
  330. package/lib/controllers/recently.js.map +0 -1
  331. package/lib/controllers/say.d.ts +0 -37
  332. package/lib/controllers/say.js +0 -25
  333. package/lib/controllers/say.js.map +0 -1
  334. package/lib/controllers/search.d.ts +0 -247
  335. package/lib/controllers/search.js +0 -32
  336. package/lib/controllers/search.js.map +0 -1
  337. package/lib/controllers/severless.d.ts +0 -24
  338. package/lib/controllers/severless.js +0 -20
  339. package/lib/controllers/severless.js.map +0 -1
  340. package/lib/controllers/snippet.d.ts +0 -24
  341. package/lib/controllers/snippet.js +0 -23
  342. package/lib/controllers/snippet.js.map +0 -1
  343. package/lib/controllers/topic.d.ts +0 -26
  344. package/lib/controllers/topic.js +0 -22
  345. package/lib/controllers/topic.js.map +0 -1
  346. package/lib/controllers/user.d.ts +0 -70
  347. package/lib/controllers/user.js +0 -44
  348. package/lib/controllers/user.js.map +0 -1
  349. package/lib/core/attach-request.d.ts +0 -2
  350. package/lib/core/attach-request.js +0 -40
  351. package/lib/core/attach-request.js.map +0 -1
  352. package/lib/core/client.d.ts +0 -29
  353. package/lib/core/client.js +0 -190
  354. package/lib/core/client.js.map +0 -1
  355. package/lib/core/error.d.ts +0 -6
  356. package/lib/core/error.js +0 -13
  357. package/lib/core/error.js.map +0 -1
  358. package/lib/core/index.d.ts +0 -2
  359. package/lib/core/index.js +0 -19
  360. package/lib/core/index.js.map +0 -1
  361. package/lib/dtos/comment.d.ts +0 -6
  362. package/lib/dtos/comment.js +0 -7
  363. package/lib/dtos/comment.js.map +0 -1
  364. package/lib/index.d.ts +0 -7
  365. package/lib/index.js +0 -27
  366. package/lib/index.js.map +0 -1
  367. package/lib/interfaces/adapter.d.ts +0 -14
  368. package/lib/interfaces/adapter.js +0 -3
  369. package/lib/interfaces/adapter.js.map +0 -1
  370. package/lib/interfaces/client.d.ts +0 -13
  371. package/lib/interfaces/client.js +0 -3
  372. package/lib/interfaces/client.js.map +0 -1
  373. package/lib/interfaces/controller.d.ts +0 -4
  374. package/lib/interfaces/controller.js +0 -3
  375. package/lib/interfaces/controller.js.map +0 -1
  376. package/lib/interfaces/instance.d.ts +0 -7
  377. package/lib/interfaces/instance.js +0 -3
  378. package/lib/interfaces/instance.js.map +0 -1
  379. package/lib/interfaces/options.d.ts +0 -1
  380. package/lib/interfaces/options.js +0 -3
  381. package/lib/interfaces/options.js.map +0 -1
  382. package/lib/interfaces/params.d.ts +0 -4
  383. package/lib/interfaces/params.js +0 -3
  384. package/lib/interfaces/params.js.map +0 -1
  385. package/lib/interfaces/request.d.ts +0 -43
  386. package/lib/interfaces/request.js +0 -3
  387. package/lib/interfaces/request.js.map +0 -1
  388. package/lib/interfaces/types.d.ts +0 -2
  389. package/lib/interfaces/types.js +0 -3
  390. package/lib/interfaces/types.js.map +0 -1
  391. package/lib/models/aggregate.d.ts +0 -53
  392. package/lib/models/aggregate.js +0 -9
  393. package/lib/models/aggregate.js.map +0 -1
  394. package/lib/models/base.d.ts +0 -38
  395. package/lib/models/base.js +0 -3
  396. package/lib/models/base.js.map +0 -1
  397. package/lib/models/category.d.ts +0 -22
  398. package/lib/models/category.js +0 -9
  399. package/lib/models/category.js.map +0 -1
  400. package/lib/models/comment.d.ts +0 -37
  401. package/lib/models/comment.js +0 -16
  402. package/lib/models/comment.js.map +0 -1
  403. package/lib/models/index.d.ts +0 -14
  404. package/lib/models/index.js +0 -31
  405. package/lib/models/index.js.map +0 -1
  406. package/lib/models/link.d.ts +0 -22
  407. package/lib/models/link.js +0 -17
  408. package/lib/models/link.js.map +0 -1
  409. package/lib/models/note.d.ts +0 -33
  410. package/lib/models/note.js +0 -3
  411. package/lib/models/note.js.map +0 -1
  412. package/lib/models/page.d.ts +0 -14
  413. package/lib/models/page.js +0 -10
  414. package/lib/models/page.js.map +0 -1
  415. package/lib/models/post.d.ts +0 -17
  416. package/lib/models/post.js +0 -3
  417. package/lib/models/post.js.map +0 -1
  418. package/lib/models/project.d.ts +0 -11
  419. package/lib/models/project.js +0 -3
  420. package/lib/models/project.js.map +0 -1
  421. package/lib/models/recently.d.ts +0 -26
  422. package/lib/models/recently.js +0 -10
  423. package/lib/models/recently.js.map +0 -1
  424. package/lib/models/say.d.ts +0 -6
  425. package/lib/models/say.js +0 -3
  426. package/lib/models/say.js.map +0 -1
  427. package/lib/models/setting.d.ts +0 -66
  428. package/lib/models/setting.js +0 -3
  429. package/lib/models/setting.js.map +0 -1
  430. package/lib/models/snippet.d.ts +0 -18
  431. package/lib/models/snippet.js +0 -11
  432. package/lib/models/snippet.js.map +0 -1
  433. package/lib/models/topic.d.ts +0 -8
  434. package/lib/models/topic.js +0 -3
  435. package/lib/models/topic.js.map +0 -1
  436. package/lib/models/user.d.ts +0 -21
  437. package/lib/models/user.js +0 -3
  438. package/lib/models/user.js.map +0 -1
  439. package/lib/utils/auto-bind.d.ts +0 -4
  440. package/lib/utils/auto-bind.js +0 -40
  441. package/lib/utils/auto-bind.js.map +0 -1
  442. package/lib/utils/camelcase-keys.d.ts +0 -6
  443. package/lib/utils/camelcase-keys.js +0 -28
  444. package/lib/utils/camelcase-keys.js.map +0 -1
  445. package/lib/utils/index.d.ts +0 -5
  446. package/lib/utils/index.js +0 -50
  447. package/lib/utils/index.js.map +0 -1
  448. package/lib/utils/path.d.ts +0 -1
  449. package/lib/utils/path.js +0 -11
  450. package/lib/utils/path.js.map +0 -1
  451. package/lib/vitest.config.d.ts +0 -2
  452. package/lib/vitest.config.js +0 -17
  453. package/lib/vitest.config.js.map +0 -1
  454. package/types/adaptors/axios.d.ts +0 -4
  455. package/types/adaptors/ky.d.ts +0 -23
  456. package/types/adaptors/umi-request.d.ts +0 -4
  457. package/types/controllers/aggregate.d.ts +0 -64
  458. package/types/controllers/base.d.ts +0 -43
  459. package/types/controllers/category.d.ts +0 -115
  460. package/types/controllers/comment.d.ts +0 -81
  461. package/types/controllers/index.d.ts +0 -18
  462. package/types/controllers/link.d.ts +0 -20
  463. package/types/controllers/note.d.ts +0 -103
  464. package/types/controllers/page.d.ts +0 -59
  465. package/types/controllers/post.d.ts +0 -72
  466. package/types/controllers/project.d.ts +0 -15
  467. package/types/controllers/recently.d.ts +0 -61
  468. package/types/controllers/say.d.ts +0 -37
  469. package/types/controllers/search.d.ts +0 -247
  470. package/types/controllers/severless.d.ts +0 -24
  471. package/types/controllers/snippet.d.ts +0 -24
  472. package/types/controllers/topic.d.ts +0 -26
  473. package/types/controllers/user.d.ts +0 -70
  474. package/types/core/attach-request.d.ts +0 -2
  475. package/types/core/client.d.ts +0 -29
  476. package/types/core/error.d.ts +0 -6
  477. package/types/core/index.d.ts +0 -2
  478. package/types/dtos/comment.d.ts +0 -6
  479. package/types/index.d.ts +0 -7
  480. package/types/interfaces/adapter.d.ts +0 -14
  481. package/types/interfaces/client.d.ts +0 -13
  482. package/types/interfaces/controller.d.ts +0 -4
  483. package/types/interfaces/instance.d.ts +0 -7
  484. package/types/interfaces/options.d.ts +0 -1
  485. package/types/interfaces/params.d.ts +0 -4
  486. package/types/interfaces/request.d.ts +0 -43
  487. package/types/interfaces/types.d.ts +0 -2
  488. package/types/models/aggregate.d.ts +0 -53
  489. package/types/models/base.d.ts +0 -38
  490. package/types/models/category.d.ts +0 -22
  491. package/types/models/comment.d.ts +0 -37
  492. package/types/models/index.d.ts +0 -14
  493. package/types/models/link.d.ts +0 -22
  494. package/types/models/note.d.ts +0 -33
  495. package/types/models/page.d.ts +0 -14
  496. package/types/models/post.d.ts +0 -17
  497. package/types/models/project.d.ts +0 -11
  498. package/types/models/recently.d.ts +0 -26
  499. package/types/models/say.d.ts +0 -6
  500. package/types/models/setting.d.ts +0 -66
  501. package/types/models/snippet.d.ts +0 -18
  502. package/types/models/topic.d.ts +0 -8
  503. package/types/models/user.d.ts +0 -21
  504. package/types/utils/auto-bind.d.ts +0 -4
  505. package/types/utils/camelcase-keys.d.ts +0 -6
  506. package/types/utils/index.d.ts +0 -5
  507. package/types/utils/path.d.ts +0 -1
  508. package/types/vitest.config.d.ts +0 -2
@@ -0,0 +1,293 @@
1
+ import { AxiosError, AxiosResponse } from 'axios'
2
+ import { vi } from 'vitest'
3
+
4
+ import { axiosAdaptor } from '~/adaptors/axios'
5
+ import { umiAdaptor } from '~/adaptors/umi-request'
6
+ import {
7
+ NoteController,
8
+ PostController,
9
+ allContollerNames,
10
+ allControllers,
11
+ } from '~/controllers'
12
+ import { RequestError, createClient } from '~/core'
13
+ import { IRequestAdapter } from '~/interfaces/adapter'
14
+ import { ClientOptions } from '~/interfaces/client'
15
+
16
+ const { spyOn } = vi
17
+
18
+ // axios wrapper test
19
+ const generateClient = <
20
+ Response = AxiosResponse<unknown>,
21
+ AdaptorType extends IRequestAdapter = typeof axiosAdaptor,
22
+ >(
23
+ adapter?: AdaptorType,
24
+ options?: ClientOptions,
25
+ ) =>
26
+ createClient(adapter ?? axiosAdaptor)<Response>(
27
+ 'http://127.0.0.1:2323',
28
+ options,
29
+ )
30
+ describe('test client', () => {
31
+ it('should create new client with axios', () => {
32
+ const client = generateClient()
33
+ expect(client).toBeDefined()
34
+ })
35
+
36
+ describe('client `get` method', () => {
37
+ test('case 1', async () => {
38
+ spyOn(axiosAdaptor, 'get').mockImplementation((url) => {
39
+ if (url === 'http://127.0.0.1:2323/a/a?foo=bar') {
40
+ return Promise.resolve({ data: { ok: 1 } })
41
+ }
42
+
43
+ return Promise.resolve({ data: null })
44
+ })
45
+
46
+ const client = generateClient()
47
+ const data = await client.proxy.a.a.get({ params: { foo: 'bar' } })
48
+
49
+ expect(data).toStrictEqual({ ok: 1 })
50
+ })
51
+
52
+ test('case 2', async () => {
53
+ spyOn(axiosAdaptor, 'get').mockImplementation((url) => {
54
+ if (url === 'http://127.0.0.1:2323/a/a') {
55
+ return Promise.resolve({ data: { ok: 1 } })
56
+ }
57
+
58
+ return Promise.resolve({ data: null })
59
+ })
60
+
61
+ const client = generateClient()
62
+ const data = await client.proxy.a.a.get()
63
+
64
+ expect(data).toStrictEqual({ ok: 1 })
65
+
66
+ {
67
+ spyOn(axiosAdaptor, 'get').mockImplementation((url) => {
68
+ if (url === 'http://127.0.0.1:2323/a/b') {
69
+ return Promise.resolve({ data: { ok: 1 } })
70
+ }
71
+
72
+ return Promise.resolve({ data: null })
73
+ })
74
+
75
+ const client = generateClient()
76
+ const data = await client.proxy.a.b.get()
77
+
78
+ expect(data).toStrictEqual({ ok: 1 })
79
+ }
80
+ })
81
+ })
82
+
83
+ it('should throw error if not inject other client', () => {
84
+ const client = generateClient()
85
+ allContollerNames.forEach((name) => {
86
+ expect(() => (client as any)[name].name).toThrow(
87
+ `${
88
+ name.charAt(0).toUpperCase() + name.slice(1)
89
+ } Client not inject yet, please inject with client.injectClients(...)`,
90
+ )
91
+ })
92
+ })
93
+
94
+ it('should work if inject client', () => {
95
+ const client = generateClient()
96
+
97
+ client.injectControllers(allControllers)
98
+ allContollerNames.forEach((name) => {
99
+ expect(() => (client as any)[name].name).toBeDefined()
100
+ })
101
+ })
102
+
103
+ it('should inject single client worked', () => {
104
+ const client = generateClient()
105
+
106
+ client.injectControllers(PostController)
107
+ expect(client.post.name).toBeDefined()
108
+ })
109
+
110
+ it('should inject multi client worked', () => {
111
+ const client = generateClient()
112
+
113
+ client.injectControllers(PostController, NoteController)
114
+ expect(client.post.name).toBeDefined()
115
+ expect(client.note.name).toBeDefined()
116
+ })
117
+
118
+ it('should inject controller when init', () => {
119
+ const client = createClient(axiosAdaptor)('http://127.0.0.1:2323', {
120
+ controllers: [PostController, NoteController],
121
+ })
122
+ expect(client.post.name).toBeDefined()
123
+ expect(client.note.name).toBeDefined()
124
+ })
125
+
126
+ it('should infer response wrapper type', async () => {
127
+ const client = generateClient<AxiosResponse>(axiosAdaptor)
128
+ client.injectControllers(PostController)
129
+ spyOn(axiosAdaptor, 'get').mockImplementation((url) => {
130
+ if (url === 'http://127.0.0.1:2323/posts/latest') {
131
+ return Promise.resolve({ data: { ok: 1 }, status: 200 })
132
+ }
133
+
134
+ return Promise.resolve({ data: null })
135
+ })
136
+
137
+ const data = await client.post.getLatest()
138
+
139
+ expect(data.$raw.status).toBe(200)
140
+ })
141
+
142
+ it('should infer axios instance type', async () => {
143
+ const client = generateClient<AxiosResponse>(axiosAdaptor)
144
+ spyOn(axiosAdaptor, 'get').mockImplementation((url) => {
145
+ if (url === 'http://127.0.0.1:2323/a') {
146
+ return Promise.resolve({ data: { ok: 1 }, status: 200 })
147
+ }
148
+
149
+ return Promise.resolve({ data: null })
150
+ })
151
+ expect(client.instance.default).toBe(axiosAdaptor.default)
152
+ const res = await client.proxy.a.get()
153
+ expect(res.$raw.status).toBe(200)
154
+
155
+ {
156
+ spyOn(umiAdaptor, 'get').mockImplementation((url) => {
157
+ if (url === 'http://127.0.0.1:2323/a') {
158
+ return Promise.resolve({
159
+ data: { ok: 1 },
160
+ response: { status: 200, body: {} },
161
+ })
162
+ }
163
+
164
+ return Promise.resolve({ data: null })
165
+ })
166
+ const client2 = createClient(umiAdaptor)('http://127.0.0.1:2323')
167
+ expect(client2.instance.default).toBe(umiAdaptor.default)
168
+ const res = await client2.proxy.a.get()
169
+ expect(res.$raw.response.status).toBe(200)
170
+ expect(res.$raw.response.body).toStrictEqual({})
171
+ }
172
+ })
173
+
174
+ it('should resolve joint path call toString()', () => {
175
+ const client = generateClient()
176
+ {
177
+ const path = client.proxy.foo.bar.toString()
178
+ expect(path).toBe('/foo/bar')
179
+ }
180
+
181
+ {
182
+ const path = client.proxy.foo.bar.toString(true)
183
+ expect(path).toBe('http://127.0.0.1:2323/foo/bar')
184
+ }
185
+ })
186
+
187
+ it('should do not json convert case if payload is string or other primitive type', async () => {
188
+ const client = generateClient<AxiosResponse>(axiosAdaptor)
189
+ spyOn(axiosAdaptor, 'get').mockImplementation((url) => {
190
+ if (url === 'http://127.0.0.1:2323/a') {
191
+ return Promise.resolve({ data: 'foo', status: 200 })
192
+ }
193
+
194
+ return Promise.resolve({ data: null })
195
+ })
196
+
197
+ const data = await client.proxy.a.get()
198
+ expect(data).toBe('foo')
199
+ })
200
+
201
+ it('should throw exception with custom message and code', async () => {
202
+ const client = generateClient<AxiosResponse>(axiosAdaptor, {
203
+ // @ts-ignore
204
+ getCodeMessageFromException: (e: AxiosError) => {
205
+ return {
206
+ code: e.response?.status,
207
+ message: e.message,
208
+ }
209
+ },
210
+ })
211
+ spyOn(axiosAdaptor, 'get').mockImplementation(() => {
212
+ return Promise.reject(
213
+ new AxiosError(
214
+ 'not found',
215
+ 'NOT_FOUND',
216
+ {},
217
+ {},
218
+ {
219
+ status: 404,
220
+ config: {},
221
+ data: {},
222
+ headers: {},
223
+ statusText: 'not found',
224
+ },
225
+ ),
226
+ )
227
+ })
228
+
229
+ try {
230
+ await client.proxy.a.get()
231
+ } catch (er: any) {
232
+ expect(er).toBeInstanceOf(RequestError)
233
+ expect(er.status).toBe(404)
234
+ }
235
+ })
236
+
237
+ it('should throw custom exception', async () => {
238
+ class MyRequestError extends Error {
239
+ constructor(
240
+ message: string,
241
+ public status: number,
242
+ public path: string,
243
+ public raw: any,
244
+ ) {
245
+ super(message)
246
+ }
247
+
248
+ toResponse() {
249
+ return {
250
+ status: this.status,
251
+ }
252
+ }
253
+ }
254
+
255
+ const client = generateClient<AxiosResponse>(axiosAdaptor, {
256
+ // @ts-ignore
257
+ customThrowResponseError(err) {
258
+ return new MyRequestError(
259
+ err.message,
260
+ err.response?.status,
261
+ err.path,
262
+ err.raw,
263
+ )
264
+ },
265
+ })
266
+
267
+ spyOn(axiosAdaptor, 'get').mockImplementation(() => {
268
+ return Promise.reject(
269
+ new AxiosError(
270
+ 'not found',
271
+ 'NOT_FOUND',
272
+ {},
273
+ {},
274
+ {
275
+ status: 404,
276
+ config: {},
277
+ data: {},
278
+ headers: {},
279
+ statusText: 'not found',
280
+ },
281
+ ),
282
+ )
283
+ })
284
+
285
+ try {
286
+ await client.proxy.a.get()
287
+ } catch (er: any) {
288
+ expect(er).toBeInstanceOf(MyRequestError)
289
+ expect(er.toResponse).toBeDefined()
290
+ expect(er.status).toBe(404)
291
+ }
292
+ })
293
+ })
@@ -0,0 +1,108 @@
1
+ import { allControllers } from '~/controllers'
2
+ import { HTTPClient, RequestError, createClient } from '~/core'
3
+ import { IRequestAdapter } from '~/interfaces/adapter'
4
+
5
+ import { createMockServer } from './e2e-mock-server'
6
+
7
+ export const testAdaptor = (adaptor: IRequestAdapter) => {
8
+ let client: HTTPClient
9
+ const { app, close, port } = createMockServer()
10
+
11
+ afterAll(() => {
12
+ close()
13
+ })
14
+
15
+ beforeAll(() => {
16
+ client = createClient(adaptor)(`http://localhost:${port}`)
17
+ client.injectControllers(allControllers)
18
+ })
19
+ test('get', async () => {
20
+ app.get('/posts/1', (req, res) => {
21
+ res.send({
22
+ id: '1',
23
+ category_id: '11',
24
+ })
25
+ })
26
+ const res = await client.post.getPost('1')
27
+
28
+ expect(res).toStrictEqual({
29
+ id: '1',
30
+ categoryId: '11',
31
+ })
32
+
33
+ expect(res.$raw.data.category_id).toEqual('11')
34
+ })
35
+
36
+ test('post', async () => {
37
+ app.post('/comments/1', (req, res) => {
38
+ const { body } = req
39
+
40
+ res.send({
41
+ ...body,
42
+ })
43
+ })
44
+ const dto = {
45
+ text: 'hello',
46
+ author: 'test',
47
+ mail: '1@ee.com',
48
+ }
49
+ const res = await client.comment.comment('1', dto)
50
+
51
+ expect(res).toStrictEqual(dto)
52
+ })
53
+
54
+ test('get with search query', async () => {
55
+ app.get('/search/post', (req, res) => {
56
+ if (req.query.keyword) {
57
+ return res.send({ result: 1 })
58
+ }
59
+ res.send(null)
60
+ })
61
+
62
+ const res = await client.search.search('post', 'keyword')
63
+ expect(res).toStrictEqual({ result: 1 })
64
+ })
65
+
66
+ test('rawResponse rawRequest should defined', async () => {
67
+ app.get('/search/post', (req, res) => {
68
+ if (req.query.keyword) {
69
+ return res.send({ result: 1 })
70
+ }
71
+ res.send(null)
72
+ })
73
+
74
+ const res = await client.search.search('post', 'keyword')
75
+ expect(res.$raw).toBeDefined()
76
+ expect(res.$raw.data).toBeDefined()
77
+ })
78
+
79
+ it('should error catch', async () => {
80
+ app.get('/error', (req, res) => {
81
+ res.status(500).send({
82
+ message: 'error message',
83
+ })
84
+ })
85
+ await expect(client.proxy.error.get()).rejects.toThrowError(RequestError)
86
+ })
87
+
88
+ it('should use number as path', async () => {
89
+ app.get('/1/1', (req, res) => {
90
+ res.send({ data: 1, foo_bar: 'foo' })
91
+ })
92
+
93
+ const res = await client.proxy(1)(1).get<{ data: number; fooBar: string }>()
94
+
95
+ expect(res).toStrictEqual({ data: 1, fooBar: 'foo' })
96
+ expect(res.$raw.data).toStrictEqual({ data: 1, foo_bar: 'foo' })
97
+ expect(res.$request).toBeDefined()
98
+ })
99
+
100
+ it('should get string payload', async () => {
101
+ app.get('/string', (req, res) => {
102
+ res.send('x')
103
+ })
104
+
105
+ const res = await client.proxy('string').get<string>()
106
+ expect(res).toStrictEqual('x')
107
+ })
108
+ }
@@ -0,0 +1,22 @@
1
+ import cors from 'cors'
2
+ import express from 'express'
3
+ import { AddressInfo } from 'net'
4
+
5
+ type Express = ReturnType<typeof express>
6
+ export const createMockServer = (options: { port?: number } = {}) => {
7
+ const { port = 0 } = options
8
+
9
+ const app: Express = express()
10
+ app.use(express.json())
11
+ app.use(cors())
12
+ const server = app.listen(port)
13
+
14
+ return {
15
+ app,
16
+ port: (server.address() as AddressInfo).port,
17
+ server,
18
+ close() {
19
+ server.close()
20
+ },
21
+ }
22
+ }
@@ -0,0 +1,39 @@
1
+ // @ts-nocheck
2
+
3
+ /* eslint-disable */
4
+ import AbortController from 'abort-controller'
5
+ import fetch, { Headers, Request, Response } from 'node-fetch'
6
+
7
+ const TEN_MEGABYTES = 1000 * 1000 * 10
8
+
9
+ if (!globalThis.fetch) {
10
+ globalThis.fetch = (url, options) =>
11
+ fetch(url, { highWaterMark: TEN_MEGABYTES, ...options })
12
+ }
13
+
14
+ if (!globalThis.Headers) {
15
+ globalThis.Headers = Headers
16
+ }
17
+
18
+ if (!globalThis.Request) {
19
+ globalThis.Request = Request
20
+ }
21
+
22
+ if (!globalThis.Response) {
23
+ globalThis.Response = Response
24
+ }
25
+
26
+ if (!globalThis.AbortController) {
27
+ globalThis.AbortController = AbortController
28
+ }
29
+
30
+ if (!globalThis.ReadableStream) {
31
+ try {
32
+ // eslint-disable-next-line node/file-extension-in-import, node/no-unsupported-features/es-syntax
33
+ globalThis.ReadableStream = await import(
34
+ 'web-streams-polyfill/ponyfill/es2018'
35
+ )
36
+ } catch {}
37
+ }
38
+
39
+ export {}
@@ -0,0 +1,11 @@
1
+ import { axiosAdaptor } from '~/adaptors/axios'
2
+ import { HTTPClient, createClient } from '~/core'
3
+ import { IController } from '~/interfaces/controller'
4
+
5
+ export const mockRequestInstance = (
6
+ injectController: new (client: HTTPClient) => IController,
7
+ ) => {
8
+ const client = createClient(axiosAdaptor)('https://api.innei.ren/v2')
9
+ client.injectControllers(injectController)
10
+ return client
11
+ }
@@ -0,0 +1,76 @@
1
+ import { isEqual } from 'lodash'
2
+ import { URLSearchParams } from 'url'
3
+ import { vi } from 'vitest'
4
+
5
+ import { axiosAdaptor } from '~/adaptors/axios'
6
+
7
+ const { spyOn } = vi
8
+
9
+ export const buildResponseDataWrapper = (data: any) => ({ data })
10
+
11
+ export const mockResponse = <T>(
12
+ path: string,
13
+ data: T,
14
+ method = 'get',
15
+ requestBody?: any,
16
+ ) => {
17
+ const exceptUrlObject = new URL(
18
+ path.startsWith('http')
19
+ ? path
20
+ : `https://example.com/${path.replace(/^\//, '')}`,
21
+ )
22
+ // @ts-ignore
23
+ spyOn(axiosAdaptor, method).mockImplementation(
24
+ // @ts-ignore
25
+ async (requestUrl: string, options: any) => {
26
+ const requestUrlObject = new URL(requestUrl)
27
+
28
+ if (requestBody) {
29
+ const { data } = options || {}
30
+ if (!isEqual(requestBody, data)) {
31
+ throw new Error(
32
+ `body not equal, got: ${JSON.stringify(
33
+ data,
34
+ )} except: ${JSON.stringify(requestBody)}`,
35
+ )
36
+ }
37
+ }
38
+
39
+ if (
40
+ requestUrlObject.pathname.endsWith(exceptUrlObject.pathname) &&
41
+ (exceptUrlObject.search
42
+ ? isSearchEqual(
43
+ exceptUrlObject.searchParams,
44
+ requestUrlObject.searchParams,
45
+ )
46
+ : true)
47
+ ) {
48
+ return buildResponseDataWrapper(data)
49
+ } else {
50
+ return buildResponseDataWrapper({
51
+ error: 1,
52
+ requestPath: requestUrlObject.pathname + requestUrlObject.search,
53
+ expectPath: path,
54
+ })
55
+ }
56
+ },
57
+ )
58
+
59
+ return data
60
+ }
61
+
62
+ const isSearchEqual = (a: URLSearchParams, b: URLSearchParams) => {
63
+ const keys = Array.from(a.keys()).sort()
64
+ if (keys.toString() !== Array.from(b.keys()).sort().toString()) {
65
+ return false
66
+ }
67
+ return keys.every((key) => {
68
+ const res = a.get(key) === b.get(key)
69
+ if (!res) {
70
+ console.log(
71
+ `key ${key} not equal, receive ${a.get(key)} want ${b.get(key)}`,
72
+ )
73
+ }
74
+ return res
75
+ })
76
+ }