@keboola/api-client 3.0.1 → 5.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 (309) hide show
  1. package/README.md +34 -6
  2. package/dist/ai/index.cjs +4 -3
  3. package/dist/ai/index.d.cts +5 -10
  4. package/dist/ai/index.d.ts +5 -10
  5. package/dist/ai/index.js +3 -2
  6. package/dist/ai/types.d.cts +2 -2
  7. package/dist/ai/types.d.ts +2 -2
  8. package/dist/assets/index.cjs +4 -3
  9. package/dist/assets/index.d.cts +2 -2
  10. package/dist/assets/index.d.ts +2 -2
  11. package/dist/assets/index.js +3 -2
  12. package/dist/{authMiddleware-Dcy9gRT9.d.ts → authMiddleware-B0p06GYQ.d.ts} +1 -1
  13. package/dist/{authMiddleware-CeIxAJQ5.d.cts → authMiddleware-vNb2hfLP.d.cts} +1 -1
  14. package/dist/chat/index.cjs +4 -3
  15. package/dist/chat/index.d.cts +4 -4
  16. package/dist/chat/index.d.ts +4 -4
  17. package/dist/chat/index.js +3 -2
  18. package/dist/chat/types.d.cts +2 -2
  19. package/dist/chat/types.d.ts +2 -2
  20. package/dist/{chunk-Q6T6GRDR.js → chunk-2CTHLPTU.js} +12 -5
  21. package/dist/chunk-2CTHLPTU.js.map +1 -0
  22. package/dist/{chunk-BA2JMZP6.cjs → chunk-2EWL5BAZ.cjs} +4 -4
  23. package/dist/{chunk-BA2JMZP6.cjs.map → chunk-2EWL5BAZ.cjs.map} +1 -1
  24. package/dist/{chunk-LBVYZLWL.js → chunk-2NLVV2MF.js} +3 -3
  25. package/dist/{chunk-LBVYZLWL.js.map → chunk-2NLVV2MF.js.map} +1 -1
  26. package/dist/{chunk-MTFRH3R5.cjs → chunk-3CIPWA33.cjs} +4 -23
  27. package/dist/chunk-3CIPWA33.cjs.map +1 -0
  28. package/dist/{chunk-RBGTWJ7G.js → chunk-4FU45NEU.js} +7 -5
  29. package/dist/chunk-4FU45NEU.js.map +1 -0
  30. package/dist/chunk-4I6TJWBG.cjs +38 -0
  31. package/dist/chunk-4I6TJWBG.cjs.map +1 -0
  32. package/dist/{chunk-3DW7RIEB.js → chunk-4IBEYSSA.js} +7 -5
  33. package/dist/chunk-4IBEYSSA.js.map +1 -0
  34. package/dist/{chunk-T66CY2YX.js → chunk-4NUA46VD.js} +473 -41
  35. package/dist/chunk-4NUA46VD.js.map +1 -0
  36. package/dist/{chunk-T23NVI3Q.js → chunk-5XADEX3R.js} +7 -5
  37. package/dist/chunk-5XADEX3R.js.map +1 -0
  38. package/dist/{chunk-V35JLM5Q.js → chunk-65YXOZDQ.js} +7 -4
  39. package/dist/chunk-65YXOZDQ.js.map +1 -0
  40. package/dist/{chunk-M4PFR3OS.js → chunk-6DPZQRNC.js} +8 -5
  41. package/dist/chunk-6DPZQRNC.js.map +1 -0
  42. package/dist/{chunk-GLQZHLLN.js → chunk-7JOV7PXU.js} +7 -5
  43. package/dist/chunk-7JOV7PXU.js.map +1 -0
  44. package/dist/{chunk-OAKTIIG4.js → chunk-7PPUK4HS.js} +4 -3
  45. package/dist/chunk-7PPUK4HS.js.map +1 -0
  46. package/dist/{chunk-ZIVZF6M2.cjs → chunk-7UQVB2SQ.cjs} +9 -7
  47. package/dist/chunk-7UQVB2SQ.cjs.map +1 -0
  48. package/dist/{chunk-RTD3XWBM.cjs → chunk-AB6LHU2Z.cjs} +11 -9
  49. package/dist/chunk-AB6LHU2Z.cjs.map +1 -0
  50. package/dist/{chunk-VLSN55I3.cjs → chunk-AWRMGLMT.cjs} +113 -3
  51. package/dist/chunk-AWRMGLMT.cjs.map +1 -0
  52. package/dist/{chunk-REXMA2IN.cjs → chunk-CFR2CKM6.cjs} +8 -6
  53. package/dist/chunk-CFR2CKM6.cjs.map +1 -0
  54. package/dist/{chunk-5YN6FED2.cjs → chunk-DGWPC6VR.cjs} +13 -6
  55. package/dist/chunk-DGWPC6VR.cjs.map +1 -0
  56. package/dist/{chunk-SDA2UO4X.cjs → chunk-DOUFVJJF.cjs} +9 -6
  57. package/dist/chunk-DOUFVJJF.cjs.map +1 -0
  58. package/dist/{chunk-76Q2CTFV.js → chunk-EDDRN2CO.js} +7 -5
  59. package/dist/chunk-EDDRN2CO.js.map +1 -0
  60. package/dist/chunk-FL54VJ35.js +32 -0
  61. package/dist/chunk-FL54VJ35.js.map +1 -0
  62. package/dist/chunk-GOC5UODV.cjs +30 -0
  63. package/dist/chunk-GOC5UODV.cjs.map +1 -0
  64. package/dist/{chunk-5PUNJJAR.js → chunk-JKXQFEY7.js} +7 -5
  65. package/dist/chunk-JKXQFEY7.js.map +1 -0
  66. package/dist/chunk-KKZP4DUR.cjs +340 -0
  67. package/dist/chunk-KKZP4DUR.cjs.map +1 -0
  68. package/dist/{chunk-2ZMZ4KWJ.js → chunk-KQ2QNGRX.js} +113 -3
  69. package/dist/chunk-KQ2QNGRX.js.map +1 -0
  70. package/dist/{chunk-ECQZAWH3.cjs → chunk-KT4MFNBC.cjs} +8 -6
  71. package/dist/chunk-KT4MFNBC.cjs.map +1 -0
  72. package/dist/{chunk-RBW5ABSQ.js → chunk-MUQ7TAWH.js} +126 -7
  73. package/dist/chunk-MUQ7TAWH.js.map +1 -0
  74. package/dist/{chunk-D2ZTB5R2.cjs → chunk-OAQGC32L.cjs} +135 -16
  75. package/dist/chunk-OAQGC32L.cjs.map +1 -0
  76. package/dist/chunk-OJJ3QLZP.js +338 -0
  77. package/dist/chunk-OJJ3QLZP.js.map +1 -0
  78. package/dist/{chunk-5DVEQBCD.cjs → chunk-P4CQFG3X.cjs} +11 -9
  79. package/dist/chunk-P4CQFG3X.cjs.map +1 -0
  80. package/dist/{chunk-IL2PAEG3.cjs → chunk-RF64RAHW.cjs} +8 -6
  81. package/dist/chunk-RF64RAHW.cjs.map +1 -0
  82. package/dist/{chunk-AYXQJONA.cjs → chunk-RPNL672Y.cjs} +4 -4
  83. package/dist/chunk-RPNL672Y.cjs.map +1 -0
  84. package/dist/{chunk-HLGMFFDF.js → chunk-S7HIK7XY.js} +7 -5
  85. package/dist/chunk-S7HIK7XY.js.map +1 -0
  86. package/dist/{chunk-ROBQ2CV7.cjs → chunk-T7UDL2KI.cjs} +475 -44
  87. package/dist/chunk-T7UDL2KI.cjs.map +1 -0
  88. package/dist/{chunk-PM2FAMWT.js → chunk-UT3GUUCO.js} +7 -5
  89. package/dist/chunk-UT3GUUCO.js.map +1 -0
  90. package/dist/chunk-UUY6LQT6.cjs +267 -0
  91. package/dist/chunk-UUY6LQT6.cjs.map +1 -0
  92. package/dist/{chunk-LI3BAYDV.cjs → chunk-V32CB5U2.cjs} +8 -6
  93. package/dist/chunk-V32CB5U2.cjs.map +1 -0
  94. package/dist/{chunk-6D3MJRXE.cjs → chunk-VZROPAWL.cjs} +8 -6
  95. package/dist/chunk-VZROPAWL.cjs.map +1 -0
  96. package/dist/{chunk-6HBXNLB7.cjs → chunk-WLS43HX4.cjs} +8 -6
  97. package/dist/chunk-WLS43HX4.cjs.map +1 -0
  98. package/dist/{chunk-KOO3ZG5X.cjs → chunk-WOGG723K.cjs} +8 -5
  99. package/dist/{chunk-V35JLM5Q.js.map → chunk-WOGG723K.cjs.map} +1 -1
  100. package/dist/{chunk-4TENBFWN.cjs → chunk-XHQZ4TF7.cjs} +11 -6
  101. package/dist/chunk-XHQZ4TF7.cjs.map +1 -0
  102. package/dist/{chunk-QXWPUKK2.js → chunk-XI6R76X3.js} +4 -20
  103. package/dist/chunk-XI6R76X3.js.map +1 -0
  104. package/dist/{chunk-6TUGEXVX.js → chunk-XRHAE4SD.js} +3 -3
  105. package/dist/{chunk-6TUGEXVX.js.map → chunk-XRHAE4SD.js.map} +1 -1
  106. package/dist/{chunk-ZQPET6GI.js → chunk-Y3RILILK.js} +10 -5
  107. package/dist/chunk-Y3RILILK.js.map +1 -0
  108. package/dist/{chunk-CQFZ7PGZ.js → chunk-YH52X52J.js} +7 -5
  109. package/dist/chunk-YH52X52J.js.map +1 -0
  110. package/dist/chunk-ZOREOLGE.js +264 -0
  111. package/dist/chunk-ZOREOLGE.js.map +1 -0
  112. package/dist/{createGenericFetchClient-Cp2By_KQ.d.ts → createGenericFetchClient-Gpom91V-.d.ts} +1 -1
  113. package/dist/{createGenericFetchClient-DuW7iSRy.d.cts → createGenericFetchClient-yfcpR7qD.d.cts} +1 -1
  114. package/dist/{createOpenapiFetchClient-DhL2gQvd.d.ts → createOpenapiFetchClient-B44nXiti.d.ts} +2 -2
  115. package/dist/{createOpenapiFetchClient-BuKDZcLD.d.cts → createOpenapiFetchClient-Ci0-Qe53.d.cts} +2 -2
  116. package/dist/dataScience/index.cjs +5 -4
  117. package/dist/dataScience/index.d.cts +26 -6
  118. package/dist/dataScience/index.d.ts +26 -6
  119. package/dist/dataScience/index.js +3 -2
  120. package/dist/dataScience/types.d.cts +2 -2
  121. package/dist/dataScience/types.d.ts +2 -2
  122. package/dist/domain/permissions/index.cjs +5 -11
  123. package/dist/domain/permissions/index.cjs.map +1 -1
  124. package/dist/domain/permissions/index.d.cts +3 -2
  125. package/dist/domain/permissions/index.d.ts +3 -2
  126. package/dist/domain/permissions/index.js +1 -7
  127. package/dist/domain/permissions/index.js.map +1 -1
  128. package/dist/domain/storageTable/index.cjs +9 -260
  129. package/dist/domain/storageTable/index.cjs.map +1 -1
  130. package/dist/domain/storageTable/index.js +1 -262
  131. package/dist/domain/storageTable/index.js.map +1 -1
  132. package/dist/editor/index.cjs +4 -3
  133. package/dist/editor/index.d.cts +4 -4
  134. package/dist/editor/index.d.ts +4 -4
  135. package/dist/editor/index.js +3 -2
  136. package/dist/editor/types.d.cts +2 -2
  137. package/dist/editor/types.d.ts +2 -2
  138. package/dist/encryption/index.cjs +4 -3
  139. package/dist/encryption/index.d.cts +2 -2
  140. package/dist/encryption/index.d.ts +2 -2
  141. package/dist/encryption/index.js +3 -2
  142. package/dist/import/index.cjs +4 -3
  143. package/dist/import/index.d.cts +2 -2
  144. package/dist/import/index.d.ts +2 -2
  145. package/dist/import/index.js +3 -2
  146. package/dist/index-BEE_qeId.d.ts +1511 -0
  147. package/dist/index-KHRrA2IR.d.cts +1511 -0
  148. package/dist/index.cjs +299 -160
  149. package/dist/index.cjs.map +1 -1
  150. package/dist/index.d.cts +3048 -1028
  151. package/dist/index.d.ts +3048 -1028
  152. package/dist/index.js +244 -108
  153. package/dist/index.js.map +1 -1
  154. package/dist/management/index.cjs +6 -5
  155. package/dist/management/index.d.cts +137 -69
  156. package/dist/management/index.d.ts +137 -69
  157. package/dist/management/index.js +4 -3
  158. package/dist/management/types.d.cts +2 -2
  159. package/dist/management/types.d.ts +2 -2
  160. package/dist/metastore/index.cjs +4 -3
  161. package/dist/metastore/index.d.cts +5 -5
  162. package/dist/metastore/index.d.ts +5 -5
  163. package/dist/metastore/index.js +3 -2
  164. package/dist/metastore/types.d.cts +2 -2
  165. package/dist/metastore/types.d.ts +2 -2
  166. package/dist/oauth/index.cjs +4 -3
  167. package/dist/oauth/index.d.cts +2 -2
  168. package/dist/oauth/index.d.ts +2 -2
  169. package/dist/oauth/index.js +3 -2
  170. package/dist/{project-CYhB6rYN.d.cts → project-C4K5Dzoy.d.cts} +1 -1
  171. package/dist/{project-Bzslbq4u.d.ts → project-COwNmNoc.d.ts} +1 -1
  172. package/dist/queryService/index.cjs +4 -3
  173. package/dist/queryService/index.d.cts +4 -4
  174. package/dist/queryService/index.d.ts +4 -4
  175. package/dist/queryService/index.js +3 -2
  176. package/dist/queryService/types.d.cts +2 -2
  177. package/dist/queryService/types.d.ts +2 -2
  178. package/dist/queue/index.cjs +4 -3
  179. package/dist/queue/index.d.cts +4 -4
  180. package/dist/queue/index.d.ts +4 -4
  181. package/dist/queue/index.js +3 -2
  182. package/dist/queue/types.d.cts +2 -2
  183. package/dist/queue/types.d.ts +2 -2
  184. package/dist/sdk/configurations/index.d.cts +3 -2
  185. package/dist/sdk/configurations/index.d.ts +3 -2
  186. package/dist/sdk/storage/index.cjs +11 -11
  187. package/dist/sdk/storage/index.d.cts +7 -7
  188. package/dist/sdk/storage/index.d.ts +7 -7
  189. package/dist/sdk/storage/index.js +1 -1
  190. package/dist/sdk/tag/index.d.cts +4 -4
  191. package/dist/sdk/tag/index.d.ts +4 -4
  192. package/dist/sdk/tag/types.d.cts +4 -4
  193. package/dist/sdk/tag/types.d.ts +4 -4
  194. package/dist/sdk/vault/index.d.cts +2 -2
  195. package/dist/sdk/vault/index.d.ts +2 -2
  196. package/dist/status/index.cjs +4 -3
  197. package/dist/status/index.d.cts +2 -2
  198. package/dist/status/index.d.ts +2 -2
  199. package/dist/status/index.js +3 -2
  200. package/dist/storage/index.cjs +4 -7
  201. package/dist/storage/index.d.cts +6 -10
  202. package/dist/storage/index.d.ts +6 -10
  203. package/dist/storage/index.js +3 -2
  204. package/dist/storage/types.d.cts +451 -11617
  205. package/dist/storage/types.d.ts +451 -11617
  206. package/dist/storageSdk--0Hh4UCE.d.ts +746 -0
  207. package/dist/storageSdk-DJz6WcW3.d.cts +746 -0
  208. package/dist/stream/index.cjs +14 -0
  209. package/dist/stream/index.cjs.map +1 -0
  210. package/dist/stream/index.d.cts +348 -0
  211. package/dist/stream/index.d.ts +348 -0
  212. package/dist/stream/index.js +5 -0
  213. package/dist/stream/index.js.map +1 -0
  214. package/dist/stream/types.cjs +4 -0
  215. package/dist/stream/types.cjs.map +1 -0
  216. package/dist/stream/types.d.cts +2 -0
  217. package/dist/stream/types.d.ts +2 -0
  218. package/dist/stream/types.js +3 -0
  219. package/dist/stream/types.js.map +1 -0
  220. package/dist/syncActions/index.cjs +4 -3
  221. package/dist/syncActions/index.d.cts +5 -7
  222. package/dist/syncActions/index.d.ts +5 -7
  223. package/dist/syncActions/index.js +3 -2
  224. package/dist/syncActions/types.d.cts +1 -1
  225. package/dist/syncActions/types.d.ts +1 -1
  226. package/dist/telemetry/index.cjs +4 -3
  227. package/dist/telemetry/index.d.cts +3 -3
  228. package/dist/telemetry/index.d.ts +3 -3
  229. package/dist/telemetry/index.js +3 -2
  230. package/dist/{types-CNkgmuhe.d.cts → types-Bc-H4gfv.d.cts} +1 -1
  231. package/dist/{types-CRSKcua9.d.cts → types-BxjcUj-y.d.cts} +1 -1
  232. package/dist/{types-CqWXdTMg.d.ts → types-CFd7q2ed.d.ts} +1 -1
  233. package/dist/{types-DBVQGCI1.d.cts → types-CWebeQXy.d.cts} +1 -1
  234. package/dist/{types-DJkU9gvB.d.cts → types-D9cNOf-3.d.cts} +1 -1
  235. package/dist/types-DFWnAftN.d.cts +7523 -0
  236. package/dist/{types-B51cQMrX.d.ts → types-DFbHRDdR.d.ts} +1 -1
  237. package/dist/types-DMC601TE.d.cts +14375 -0
  238. package/dist/types-DMC601TE.d.ts +14375 -0
  239. package/dist/{types-C-bd4ArM.d.cts → types-DTkxk0fW.d.cts} +1 -1
  240. package/dist/{types-cH0_hkCW.d.ts → types-DacFMc6L.d.ts} +1 -1
  241. package/dist/types-DcL25GqY.d.cts +15820 -0
  242. package/dist/types-Dfw6a58i.d.ts +15820 -0
  243. package/dist/{types-Dws8mFNY.d.cts → types-DiC2wKsx.d.cts} +1 -1
  244. package/dist/types-Dv3vN7M9.d.ts +7523 -0
  245. package/dist/{types-Bom8wyth.d.ts → types-DxJD6LIN.d.cts} +1 -0
  246. package/dist/{types-Bom8wyth.d.cts → types-DxJD6LIN.d.ts} +1 -0
  247. package/dist/{types-DzwzVgyG.d.ts → types-JvKRS8Qd.d.ts} +1 -1
  248. package/dist/{types-BY0tjg2Q.d.ts → types-Mghz1gMD.d.ts} +1 -1
  249. package/dist/{types-C7mpAfq-.d.cts → types-jKnx7Tm_.d.cts} +1 -1
  250. package/dist/{types-C7mpAfq-.d.ts → types-jKnx7Tm_.d.ts} +1 -1
  251. package/dist/{types-CGMJT3JL.d.ts → types-yKV1EX6f.d.ts} +1 -1
  252. package/dist/{utils-BNQZiNOu.d.ts → utils-Cl4emy8g.d.ts} +567 -3
  253. package/dist/{utils-DE09pDTi.d.cts → utils-JsCYFmHj.d.cts} +567 -3
  254. package/dist/vault/index.cjs +4 -3
  255. package/dist/vault/index.d.cts +3 -3
  256. package/dist/vault/index.d.ts +3 -3
  257. package/dist/vault/index.js +3 -2
  258. package/dist/vault/types.d.cts +1 -1
  259. package/dist/vault/types.d.ts +1 -1
  260. package/dist/verify/index.cjs +4 -3
  261. package/dist/verify/index.d.cts +2 -1
  262. package/dist/verify/index.d.ts +2 -1
  263. package/dist/verify/index.js +3 -2
  264. package/package.json +31 -3
  265. package/dist/chunk-2ZMZ4KWJ.js.map +0 -1
  266. package/dist/chunk-3DW7RIEB.js.map +0 -1
  267. package/dist/chunk-4TENBFWN.cjs.map +0 -1
  268. package/dist/chunk-5DVEQBCD.cjs.map +0 -1
  269. package/dist/chunk-5PUNJJAR.js.map +0 -1
  270. package/dist/chunk-5YN6FED2.cjs.map +0 -1
  271. package/dist/chunk-6D3MJRXE.cjs.map +0 -1
  272. package/dist/chunk-6FW72PC2.cjs +0 -29
  273. package/dist/chunk-6FW72PC2.cjs.map +0 -1
  274. package/dist/chunk-6HBXNLB7.cjs.map +0 -1
  275. package/dist/chunk-76Q2CTFV.js.map +0 -1
  276. package/dist/chunk-AYXQJONA.cjs.map +0 -1
  277. package/dist/chunk-CQFZ7PGZ.js.map +0 -1
  278. package/dist/chunk-D2ZTB5R2.cjs.map +0 -1
  279. package/dist/chunk-ECQZAWH3.cjs.map +0 -1
  280. package/dist/chunk-GLQZHLLN.js.map +0 -1
  281. package/dist/chunk-HLGMFFDF.js.map +0 -1
  282. package/dist/chunk-IL2PAEG3.cjs.map +0 -1
  283. package/dist/chunk-KOO3ZG5X.cjs.map +0 -1
  284. package/dist/chunk-LI3BAYDV.cjs.map +0 -1
  285. package/dist/chunk-M4PFR3OS.js.map +0 -1
  286. package/dist/chunk-MTFRH3R5.cjs.map +0 -1
  287. package/dist/chunk-OAKTIIG4.js.map +0 -1
  288. package/dist/chunk-PM2FAMWT.js.map +0 -1
  289. package/dist/chunk-Q6T6GRDR.js.map +0 -1
  290. package/dist/chunk-QXWPUKK2.js.map +0 -1
  291. package/dist/chunk-RBGTWJ7G.js.map +0 -1
  292. package/dist/chunk-RBW5ABSQ.js.map +0 -1
  293. package/dist/chunk-REXMA2IN.cjs.map +0 -1
  294. package/dist/chunk-ROBQ2CV7.cjs.map +0 -1
  295. package/dist/chunk-RTD3XWBM.cjs.map +0 -1
  296. package/dist/chunk-SDA2UO4X.cjs.map +0 -1
  297. package/dist/chunk-T23NVI3Q.js.map +0 -1
  298. package/dist/chunk-T66CY2YX.js.map +0 -1
  299. package/dist/chunk-VLSN55I3.cjs.map +0 -1
  300. package/dist/chunk-ZIVZF6M2.cjs.map +0 -1
  301. package/dist/chunk-ZQPET6GI.js.map +0 -1
  302. package/dist/storageClient-C5R3H96R.d.cts +0 -631
  303. package/dist/storageClient-DBiS4voo.d.ts +0 -631
  304. package/dist/storageSdk-B7Iq38Vh.d.cts +0 -143
  305. package/dist/storageSdk-BnIemr2s.d.ts +0 -143
  306. package/dist/types-BTcT8Q0T.d.cts +0 -8605
  307. package/dist/types-BTcT8Q0T.d.ts +0 -8605
  308. package/dist/types-DYMMsuU0.d.cts +0 -78
  309. package/dist/types-DYMMsuU0.d.ts +0 -78
@@ -1,5 +1,6 @@
1
1
  import { concurrent } from './chunk-EBCZUGUX.js';
2
- import { createGenericFetchClient, createOpenapiFetchClient, KeboolaHttpHeader, isApiError } from './chunk-QXWPUKK2.js';
2
+ import { createGenericFetchClient, createOpenapiFetchClient, isApiError } from './chunk-XI6R76X3.js';
3
+ import { KeboolaHttpHeader } from './chunk-FL54VJ35.js';
3
4
 
4
5
  // src/clients/storage/configurationVersions/configurationVersions.ts
5
6
  var createConfigurationVersions = (client) => {
@@ -77,6 +78,12 @@ var createMergeRequests = (client) => {
77
78
  });
78
79
  return data;
79
80
  };
81
+ const mergeMergeRequest = async (id) => {
82
+ const { data } = await client.put("/v2/storage/merge-request/{id}/merge", {
83
+ path: { id }
84
+ });
85
+ return data;
86
+ };
80
87
  const getMergeRequestConflicts = async (id, signal) => {
81
88
  const { data } = await client.get(
82
89
  "/v2/storage/merge-request/{id}/conflicts",
@@ -94,6 +101,7 @@ var createMergeRequests = (client) => {
94
101
  requestReview,
95
102
  approveMergeRequest,
96
103
  requestChangesMergeRequest,
104
+ mergeMergeRequest,
97
105
  getMergeRequestConflicts
98
106
  };
99
107
  };
@@ -201,10 +209,10 @@ var toBucketListing = (raw, bucketId) => ({
201
209
 
202
210
  // src/clients/storage/buckets/buckets.ts
203
211
  var createBuckets = (client) => {
204
- const getBuckets = async (query = {}, signal) => {
212
+ const getBuckets = async (branchId, query = {}, signal) => {
205
213
  const { data } = await client.get(
206
- `/v2/storage/buckets`,
207
- { query },
214
+ `/v2/storage/branch/{branchId}/buckets`,
215
+ { path: { branchId }, query },
208
216
  { signal, queryArrayFormat: "comma" }
209
217
  );
210
218
  return data;
@@ -227,7 +235,7 @@ var createBuckets = (client) => {
227
235
  return data;
228
236
  };
229
237
  const updateBucket = async (id, body) => {
230
- const { data } = await client.patch(
238
+ const { data } = await client.put(
231
239
  `/v2/storage/buckets/{id}`,
232
240
  { path: { id }, body }
233
241
  );
@@ -315,6 +323,100 @@ var createBuckets = (client) => {
315
323
  );
316
324
  return data.map((row) => toBucketListing(row, row.bucketId));
317
325
  };
326
+ const shareBucketToOrganization = async (bucketId, signal) => {
327
+ const { data } = await client.post(
328
+ `/v2/storage/buckets/{bucketId}/share-organization`,
329
+ { path: { bucketId }, query: { async: true } },
330
+ { signal }
331
+ );
332
+ return data;
333
+ };
334
+ const shareBucketToOrganizationProject = async (bucketId, signal) => {
335
+ const { data } = await client.post(
336
+ `/v2/storage/buckets/{bucketId}/share-organization-project`,
337
+ { path: { bucketId }, query: { async: true } },
338
+ { signal }
339
+ );
340
+ return data;
341
+ };
342
+ const shareBucketToProjects = async (bucketId, body, signal) => {
343
+ const { data } = await client.post(
344
+ `/v2/storage/buckets/{bucketId}/share-to-projects`,
345
+ { path: { bucketId }, query: { async: true }, body },
346
+ { signal }
347
+ );
348
+ return data;
349
+ };
350
+ const shareBucketToUsers = async (bucketId, body, signal) => {
351
+ const { data } = await client.post(
352
+ `/v2/storage/buckets/{bucketId}/share-to-users`,
353
+ { path: { bucketId }, query: { async: true }, body },
354
+ { signal }
355
+ );
356
+ return data;
357
+ };
358
+ const unshareBucket = async (bucketId, signal) => {
359
+ const { data } = await client.delete(
360
+ `/v2/storage/buckets/{bucketId}/share`,
361
+ { path: { bucketId }, query: { async: true } },
362
+ { signal }
363
+ );
364
+ return data;
365
+ };
366
+ const forceUnlinkBucket = async (bucketId, linkedProjectId, signal) => {
367
+ const { data } = await client.delete(
368
+ `/v2/storage/buckets/{bucketId}/links/{linkedProjectId}`,
369
+ { path: { bucketId, linkedProjectId }, query: { async: true } },
370
+ { signal }
371
+ );
372
+ return data;
373
+ };
374
+ const getBucketOwner = async (bucketId, signal) => {
375
+ const { data } = await client.get(
376
+ `/v2/storage/buckets/{bucketId}/owner`,
377
+ { path: { bucketId } },
378
+ { signal }
379
+ );
380
+ return data;
381
+ };
382
+ const updateBucketOwner = async (bucketId, body, signal) => {
383
+ await client.post(
384
+ `/v2/storage/buckets/{bucketId}/owner`,
385
+ { path: { bucketId }, body },
386
+ { signal }
387
+ );
388
+ };
389
+ const refreshExternalBucket = async (bucketId, query = {}, signal) => {
390
+ const { data } = await client.put(`/v2/storage/buckets/{bucketId}/refresh`, { path: { bucketId }, query }, { signal });
391
+ return data;
392
+ };
393
+ const registerBucket = async (body, signal) => {
394
+ const { data } = await client.post(`/v2/storage/buckets/register`, { query: { async: true }, body }, { signal });
395
+ return data;
396
+ };
397
+ const getBucketRegistrationGuide = async (query, signal) => {
398
+ const { data } = await client.get(
399
+ `/v2/storage/buckets/register-guide`,
400
+ { query },
401
+ { signal }
402
+ );
403
+ return data;
404
+ };
405
+ const sharedBuckets = async (signal) => {
406
+ const { data } = await client.get(`/v2/storage/shared-buckets`, {}, { signal });
407
+ return data;
408
+ };
409
+ const saveBucketMetadata = async (bucketId, body, signal) => {
410
+ const { data } = await client.post(`/v2/storage/buckets/{bucketId}/metadata`, { path: { bucketId }, body }, { signal });
411
+ return data;
412
+ };
413
+ const deleteBucketMetadata = async (bucketId, metadataId, signal) => {
414
+ await client.delete(
415
+ `/v2/storage/buckets/{bucketId}/metadata/{metadataId}`,
416
+ { path: { bucketId, metadataId } },
417
+ { signal }
418
+ );
419
+ };
318
420
  return {
319
421
  getBuckets,
320
422
  getBucket,
@@ -328,7 +430,72 @@ var createBuckets = (client) => {
328
430
  createListing,
329
431
  updateListing,
330
432
  deleteListing,
331
- listListings
433
+ listListings,
434
+ shareBucketToOrganization,
435
+ shareBucketToOrganizationProject,
436
+ shareBucketToProjects,
437
+ shareBucketToUsers,
438
+ unshareBucket,
439
+ forceUnlinkBucket,
440
+ getBucketOwner,
441
+ updateBucketOwner,
442
+ refreshExternalBucket,
443
+ registerBucket,
444
+ getBucketRegistrationGuide,
445
+ sharedBuckets,
446
+ saveBucketMetadata,
447
+ deleteBucketMetadata
448
+ };
449
+ };
450
+
451
+ // src/clients/storage/columns/columns.ts
452
+ var createColumns = (client) => {
453
+ const addTableColumn = async (tableId, body, signal) => {
454
+ const { data } = await client.post("/v2/storage/tables/{id}/columns", { path: { id: tableId }, body }, { signal });
455
+ return data;
456
+ };
457
+ const deleteTableColumn = async (tableId, columnName, query, signal) => {
458
+ const { data } = await client.delete(
459
+ "/v2/storage/tables/{id}/columns/{column}",
460
+ { path: { id: tableId, column: columnName }, query },
461
+ { signal }
462
+ );
463
+ return data;
464
+ };
465
+ const createTablePrimaryKey = async (tableId, body, signal) => {
466
+ const { data } = await client.post("/v2/storage/tables/{id}/primary-key", { path: { id: tableId }, body }, { signal });
467
+ return data;
468
+ };
469
+ const removeTablePrimaryKey = async (tableId, signal) => {
470
+ const { data } = await client.delete(
471
+ "/v2/storage/tables/{id}/primary-key",
472
+ { path: { id: tableId } },
473
+ { signal }
474
+ );
475
+ return data;
476
+ };
477
+ const saveColumnMetadata = async (columnId, body, signal) => {
478
+ const { data } = await client.post(
479
+ "/v2/storage/columns/{id}/metadata",
480
+ { path: { id: columnId }, body },
481
+ { signal }
482
+ );
483
+ return data;
484
+ };
485
+ const deleteColumnMetadata = async (columnId, metadataId, signal) => {
486
+ await client.delete(
487
+ "/v2/storage/columns/{id}/metadata/{metadataId}",
488
+ { path: { id: columnId, metadataId } },
489
+ { signal }
490
+ );
491
+ };
492
+ return {
493
+ addTableColumn,
494
+ deleteTableColumn,
495
+ createTablePrimaryKey,
496
+ removeTablePrimaryKey,
497
+ saveColumnMetadata,
498
+ deleteColumnMetadata
332
499
  };
333
500
  };
334
501
 
@@ -372,6 +539,18 @@ var createComponentsAndConfigurations = (client) => {
372
539
  );
373
540
  return data;
374
541
  };
542
+ const rebaseConfiguration = async ({
543
+ branchId,
544
+ componentId,
545
+ configId,
546
+ ...body
547
+ }) => {
548
+ const { data } = await client.post("/v2/storage/branch/{branchId}/components/{componentId}/configs/{configId}/rebase", {
549
+ path: { branchId, componentId, configId },
550
+ body
551
+ });
552
+ return data;
553
+ };
375
554
  const getConfigurationRowDiff = async ({ componentId, configId, rowId, branchId }, signal) => {
376
555
  const { data } = await client.get(
377
556
  "/v2/storage/branch/{branchId}/components/{componentId}/configs/{configId}/rows/{rowId}/diff",
@@ -391,6 +570,24 @@ var createComponentsAndConfigurations = (client) => {
391
570
  });
392
571
  return data;
393
572
  };
573
+ const updateConfiguration = async ({
574
+ branchId = "default",
575
+ componentId,
576
+ configId,
577
+ configuration,
578
+ ...rest
579
+ }, signal) => {
580
+ const body = {
581
+ ...rest,
582
+ ...configuration !== void 0 && { configuration: JSON.stringify(configuration) }
583
+ };
584
+ const { data } = await client.put(
585
+ "/v2/storage/branch/{branchId}/components/{componentId}/configs/{configId}",
586
+ { path: { branchId, componentId, configId }, body },
587
+ { signal }
588
+ );
589
+ return data;
590
+ };
394
591
  const deleteConfiguration = async (path) => {
395
592
  await client.delete(
396
593
  "/v2/storage/branch/{branchId}/components/{componentId}/configs/{configId}",
@@ -525,9 +722,11 @@ var createComponentsAndConfigurations = (client) => {
525
722
  searchComponentConfigurations,
526
723
  // configurations
527
724
  createConfiguration,
725
+ updateConfiguration,
528
726
  getConfiguration,
529
727
  getConfigurationDiff,
530
728
  getConfigurationRowDiff,
729
+ rebaseConfiguration,
531
730
  deleteConfiguration,
532
731
  deleteConfigurations,
533
732
  getConfigurations,
@@ -686,12 +885,62 @@ var createJobs = (client) => {
686
885
  return { getJob, getJobs };
687
886
  };
688
887
 
888
+ // src/clients/storage/refreshTokenMiddleware.ts
889
+ var isTokenRefreshEndpoint = (request) => {
890
+ const url = new URL(request.url);
891
+ return request.method === "POST" && /\/tokens\/[^/]+\/refresh$/.test(url.pathname);
892
+ };
893
+ var tryParseNewToken = (data) => {
894
+ if (data === null || typeof data !== "object") return null;
895
+ const token = data.token;
896
+ return typeof token === "string" ? token : null;
897
+ };
898
+ var createRefreshTokenMiddlware = ({ accessToken, onRefresh }) => {
899
+ let current = accessToken;
900
+ return (next) => async (request) => {
901
+ request.request.headers.set(KeboolaHttpHeader.STORAGE_API_TOKEN, current);
902
+ if (!isTokenRefreshEndpoint(request.request)) return next(request);
903
+ const response = await next(request);
904
+ const newToken = tryParseNewToken(response.data);
905
+ if (newToken === null) return response;
906
+ current = newToken;
907
+ onRefresh?.(current);
908
+ return response;
909
+ };
910
+ };
911
+
912
+ // src/clients/storage/search/search.ts
913
+ var createSearch = (client) => {
914
+ const globalSearch = async (query, signal) => {
915
+ const { data } = await client.get(
916
+ "/v2/storage/global-search",
917
+ { query },
918
+ { signal }
919
+ );
920
+ return data;
921
+ };
922
+ return { globalSearch };
923
+ };
924
+
925
+ // src/clients/storage/stats/stats.ts
926
+ var createStats = (client) => {
927
+ const getRunIdStats = async (runId, signal) => {
928
+ const { data } = await client.get(
929
+ "/v2/storage/stats",
930
+ { query: { runId } },
931
+ { signal }
932
+ );
933
+ return data;
934
+ };
935
+ return { getRunIdStats };
936
+ };
937
+
689
938
  // src/clients/storage/tables/tables.ts
690
939
  var createTables = (client) => {
691
- const getTables = async (query = { include: [] }, signal) => {
940
+ const getTables = async (branchId, query = { include: [] }, signal) => {
692
941
  const { data } = await client.get(
693
- `/v2/storage/tables`,
694
- { query },
942
+ `/v2/storage/branch/{branchId}/tables`,
943
+ { path: { branchId }, query },
695
944
  { signal, queryArrayFormat: "comma" }
696
945
  );
697
946
  return data;
@@ -745,6 +994,10 @@ var createTables = (client) => {
745
994
  const { data } = await client.post("/v2/storage/buckets/{bucketId}/tables-async", { path: { bucketId }, body }, { signal });
746
995
  return data;
747
996
  };
997
+ const createTableDefinitionAsync = async (bucketId, body, signal) => {
998
+ const { data } = await client.post("/v2/storage/buckets/{bucketId}/tables-definition", { path: { bucketId }, body }, { signal });
999
+ return data;
1000
+ };
748
1001
  const importAsync = async (tableId, body, signal) => {
749
1002
  const { data } = await client.post(
750
1003
  "/v2/storage/tables/{id}/import-async",
@@ -753,6 +1006,83 @@ var createTables = (client) => {
753
1006
  );
754
1007
  return data;
755
1008
  };
1009
+ const updateTableDefinition = async ({ branchId = "default", tableId, ...body }, signal) => {
1010
+ const { data } = await client.put(
1011
+ "/v2/storage/branch/{branchId}/tables/{tableId}/definition",
1012
+ { path: { branchId, tableId }, body },
1013
+ { signal }
1014
+ );
1015
+ return data;
1016
+ };
1017
+ const updateTable = async (tableId, body, signal) => {
1018
+ const { data } = await client.put(
1019
+ "/v2/storage/tables/{id}",
1020
+ { path: { id: tableId }, body },
1021
+ { signal }
1022
+ );
1023
+ return data;
1024
+ };
1025
+ const pullTable = async (tableId, signal) => {
1026
+ const { data } = await client.post(
1027
+ "/v2/storage/tables/{id}/pull",
1028
+ { path: { id: tableId } },
1029
+ { signal }
1030
+ );
1031
+ return data;
1032
+ };
1033
+ const createAliasTable = async (bucketId, body, signal) => {
1034
+ const { data } = await client.post("/v2/storage/buckets/{bucketId}/table-aliases", { path: { bucketId }, body }, { signal });
1035
+ return data;
1036
+ };
1037
+ const setAliasTableFilter = async (tableId, body, signal) => {
1038
+ const { data } = await client.post(
1039
+ "/v2/storage/tables/{id}/alias-filter",
1040
+ { path: { id: tableId }, body },
1041
+ { signal }
1042
+ );
1043
+ return data;
1044
+ };
1045
+ const removeAliasTableFilter = async (tableId, signal) => {
1046
+ await client.delete(
1047
+ "/v2/storage/tables/{id}/alias-filter",
1048
+ { path: { id: tableId } },
1049
+ { signal }
1050
+ );
1051
+ };
1052
+ const createSnapshot = async (tableId, body, signal) => {
1053
+ const { data } = await client.post("/v2/storage/tables/{id}/snapshots", { path: { id: tableId }, body }, { signal });
1054
+ return data;
1055
+ };
1056
+ const deleteSnapshot = async (snapshotId, signal) => {
1057
+ await client.delete(
1058
+ "/v2/storage/snapshots/{snapshotId}",
1059
+ { path: { snapshotId } },
1060
+ { signal }
1061
+ );
1062
+ };
1063
+ const loadTableSnapshots = async (tableId, signal) => {
1064
+ const { data } = await client.get(
1065
+ "/v2/storage/tables/{id}/snapshots",
1066
+ { path: { id: tableId } },
1067
+ { signal }
1068
+ );
1069
+ return data;
1070
+ };
1071
+ const saveTableMetadata = async (tableId, body, signal) => {
1072
+ const { data } = await client.post(
1073
+ "/v2/storage/tables/{id}/metadata",
1074
+ { path: { id: tableId }, body },
1075
+ { signal }
1076
+ );
1077
+ return data;
1078
+ };
1079
+ const deleteTableMetadata = async (tableId, metadataId, signal) => {
1080
+ await client.delete(
1081
+ "/v2/storage/tables/{id}/metadata/{metadataId}",
1082
+ { path: { id: tableId, metadataId } },
1083
+ { signal }
1084
+ );
1085
+ };
756
1086
  return {
757
1087
  getTables,
758
1088
  getTable,
@@ -762,7 +1092,19 @@ var createTables = (client) => {
762
1092
  deleteTableRows,
763
1093
  exportAsync,
764
1094
  createTableAsync,
765
- importAsync
1095
+ createTableDefinitionAsync,
1096
+ importAsync,
1097
+ updateTableDefinition,
1098
+ updateTable,
1099
+ pullTable,
1100
+ createAliasTable,
1101
+ setAliasTableFilter,
1102
+ removeAliasTableFilter,
1103
+ createSnapshot,
1104
+ deleteSnapshot,
1105
+ loadTableSnapshots,
1106
+ saveTableMetadata,
1107
+ deleteTableMetadata
766
1108
  };
767
1109
  };
768
1110
 
@@ -784,9 +1126,93 @@ var createTokens = (client) => {
784
1126
  );
785
1127
  return data;
786
1128
  };
1129
+ const getTokens = async (signal) => {
1130
+ const { data } = await client.get(
1131
+ "/v2/storage/tokens",
1132
+ {},
1133
+ { signal }
1134
+ );
1135
+ return data;
1136
+ };
1137
+ const createToken = async (body, signal) => {
1138
+ const { data } = await client.post(
1139
+ "/v2/storage/tokens",
1140
+ { body },
1141
+ { signal }
1142
+ );
1143
+ return data;
1144
+ };
1145
+ const updateToken = async (id, body, signal) => {
1146
+ const { data } = await client.put(
1147
+ "/v2/storage/tokens/{id}",
1148
+ { path: { id }, body },
1149
+ { signal }
1150
+ );
1151
+ return data;
1152
+ };
1153
+ const deleteToken = async (id, signal) => {
1154
+ await client.delete(
1155
+ "/v2/storage/tokens/{id}",
1156
+ { path: { id } },
1157
+ { signal }
1158
+ );
1159
+ };
1160
+ const shareToken = async (id, body, signal) => {
1161
+ await client.post(
1162
+ "/v2/storage/tokens/{id}/share",
1163
+ { path: { id }, body },
1164
+ { signal }
1165
+ );
1166
+ };
787
1167
  return {
788
1168
  verify,
789
- refresh
1169
+ refresh,
1170
+ getTokens,
1171
+ createToken,
1172
+ updateToken,
1173
+ deleteToken,
1174
+ shareToken
1175
+ };
1176
+ };
1177
+
1178
+ // src/clients/storage/triggers/triggers.ts
1179
+ var createTriggers = (client) => {
1180
+ const listTriggers = async (query, signal) => {
1181
+ const { data } = await client.get(
1182
+ "/v2/storage/triggers",
1183
+ { query },
1184
+ { signal }
1185
+ );
1186
+ return data;
1187
+ };
1188
+ const createTrigger = async (body, signal) => {
1189
+ const { data } = await client.post(
1190
+ "/v2/storage/triggers",
1191
+ { body },
1192
+ { signal }
1193
+ );
1194
+ return data;
1195
+ };
1196
+ const updateTrigger = async (triggerId, body, signal) => {
1197
+ const { data } = await client.put(
1198
+ "/v2/storage/triggers/{triggerId}",
1199
+ { path: { triggerId }, body },
1200
+ { signal }
1201
+ );
1202
+ return data;
1203
+ };
1204
+ const deleteTrigger = async (triggerId, signal) => {
1205
+ await client.delete(
1206
+ "/v2/storage/triggers/{triggerId}",
1207
+ { path: { triggerId } },
1208
+ { signal }
1209
+ );
1210
+ };
1211
+ return {
1212
+ listTriggers,
1213
+ createTrigger,
1214
+ updateTrigger,
1215
+ deleteTrigger
790
1216
  };
791
1217
  };
792
1218
 
@@ -889,6 +1315,18 @@ var createWorkspaces = (client, openApiClient) => {
889
1315
  );
890
1316
  return data;
891
1317
  };
1318
+ const inputMappingLoadPreview = async ({ branchId, body, backend }, signal) => {
1319
+ const { data } = await openApiClient.post(
1320
+ "/v2/storage/branch/{branchId}/input-mapping-load/preview",
1321
+ {
1322
+ path: { branchId: String(branchId) },
1323
+ query: backend ? { backend } : void 0,
1324
+ body
1325
+ },
1326
+ { signal }
1327
+ );
1328
+ return data;
1329
+ };
892
1330
  return {
893
1331
  getWorkspace,
894
1332
  getWorkspaces,
@@ -900,19 +1338,32 @@ var createWorkspaces = (client, openApiClient) => {
900
1338
  getWorkspaceSaml2Login,
901
1339
  getWorkspaceObjects,
902
1340
  deleteWorkspaceObjectsAsync,
903
- unloadWorkspace
1341
+ unloadWorkspace,
1342
+ inputMappingLoadPreview
904
1343
  };
905
1344
  };
906
1345
 
907
1346
  // src/clients/storage/storageClient.ts
908
- var createStorageClient = ({ baseUrl, middlewares = [] }) => {
1347
+ var createStorageClient = ({
1348
+ baseUrl,
1349
+ token,
1350
+ middlewares = [],
1351
+ onRefreshToken
1352
+ }) => {
1353
+ const allMiddlewares = onRefreshToken ? [
1354
+ ...middlewares,
1355
+ createRefreshTokenMiddlware({ accessToken: token, onRefresh: onRefreshToken })
1356
+ ] : middlewares;
1357
+ const headers = { [KeboolaHttpHeader.STORAGE_API_TOKEN]: token };
909
1358
  const client = createGenericFetchClient({
910
1359
  baseUrl,
911
- middlewares
1360
+ middlewares: allMiddlewares,
1361
+ headers
912
1362
  });
913
1363
  const openApiClient = createOpenapiFetchClient({
914
1364
  baseUrl,
915
- middlewares
1365
+ middlewares: allMiddlewares,
1366
+ headers
916
1367
  });
917
1368
  const getStackInfo = async (query, signal) => {
918
1369
  const { data } = await client.get(
@@ -927,6 +1378,7 @@ var createStorageClient = ({ baseUrl, middlewares = [] }) => {
927
1378
  events: createEvents(client),
928
1379
  files: createFiles(client),
929
1380
  tables: createTables(client),
1381
+ columns: createColumns(client),
930
1382
  branches: createBranches(client),
931
1383
  workspaces: createWorkspaces(client, openApiClient),
932
1384
  mergeRequests: createMergeRequests(openApiClient),
@@ -934,33 +1386,13 @@ var createStorageClient = ({ baseUrl, middlewares = [] }) => {
934
1386
  componentsAndConfigurations: createComponentsAndConfigurations(client),
935
1387
  configurationVersions: createConfigurationVersions(client),
936
1388
  tokens: createTokens(client),
1389
+ triggers: createTriggers(client),
1390
+ search: createSearch(client),
1391
+ stats: createStats(client),
937
1392
  getStackInfo
938
1393
  };
939
1394
  };
940
1395
 
941
- // src/clients/storage/storageTokenMiddleware.ts
942
- var isTokenRefreshEndpoint = (request) => {
943
- const url = new URL(request.url);
944
- return request.method === "POST" && /\/tokens\/[^/]+\/refresh$/.test(url.pathname);
945
- };
946
- var tryParseNewToken = (data) => {
947
- if (data === null || typeof data !== "object") return null;
948
- const token = data.token;
949
- return typeof token === "string" ? token : null;
950
- };
951
- var createStorageTokenMiddleware = (initialToken) => {
952
- let current = initialToken;
953
- return (next) => async (request) => {
954
- request.request.headers.set(KeboolaHttpHeader.STORAGE_API_TOKEN, current);
955
- const response = await next(request);
956
- if (isTokenRefreshEndpoint(request.request)) {
957
- const newToken = tryParseNewToken(response.data);
958
- if (newToken !== null) current = newToken;
959
- }
960
- return response;
961
- };
962
- };
963
-
964
- export { createStorageClient, createStorageTokenMiddleware, series };
965
- //# sourceMappingURL=chunk-T66CY2YX.js.map
966
- //# sourceMappingURL=chunk-T66CY2YX.js.map
1396
+ export { createStorageClient, series };
1397
+ //# sourceMappingURL=chunk-4NUA46VD.js.map
1398
+ //# sourceMappingURL=chunk-4NUA46VD.js.map