@keboola/api-client 1.0.1 → 3.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 (213) hide show
  1. package/dist/ai/index.cjs +5 -201
  2. package/dist/ai/index.cjs.map +1 -1
  3. package/dist/ai/index.js +2 -201
  4. package/dist/ai/index.js.map +1 -1
  5. package/dist/assets/index.cjs +5 -180
  6. package/dist/assets/index.cjs.map +1 -1
  7. package/dist/assets/index.js +2 -180
  8. package/dist/assets/index.js.map +1 -1
  9. package/dist/chat/index.cjs +6 -422
  10. package/dist/chat/index.cjs.map +1 -1
  11. package/dist/chat/index.js +3 -422
  12. package/dist/chat/index.js.map +1 -1
  13. package/dist/chat/suggestions.cjs +70 -152
  14. package/dist/chat/suggestions.cjs.map +1 -1
  15. package/dist/chat/suggestions.js +1 -138
  16. package/dist/chat/suggestions.js.map +1 -1
  17. package/dist/chunk-3B7L6MCG.js +189 -0
  18. package/dist/chunk-3B7L6MCG.js.map +1 -0
  19. package/dist/chunk-3T54WH4X.cjs +42 -0
  20. package/dist/chunk-3T54WH4X.cjs.map +1 -0
  21. package/dist/chunk-3Y6NK7TC.js +34 -0
  22. package/dist/chunk-3Y6NK7TC.js.map +1 -0
  23. package/dist/chunk-4RC5E3SL.js +140 -0
  24. package/dist/chunk-4RC5E3SL.js.map +1 -0
  25. package/dist/chunk-633QJMHH.cjs +73 -0
  26. package/dist/chunk-633QJMHH.cjs.map +1 -0
  27. package/dist/chunk-6RQDX6JY.cjs +132 -0
  28. package/dist/chunk-6RQDX6JY.cjs.map +1 -0
  29. package/dist/chunk-76AHKXLC.cjs +29 -0
  30. package/dist/chunk-76AHKXLC.cjs.map +1 -0
  31. package/dist/chunk-7FY6COWG.js +71 -0
  32. package/dist/chunk-7FY6COWG.js.map +1 -0
  33. package/dist/chunk-7J2R6XHB.js +3 -0
  34. package/dist/chunk-7J2R6XHB.js.map +1 -0
  35. package/dist/chunk-BGLICNTG.cjs +33 -0
  36. package/dist/chunk-BGLICNTG.cjs.map +1 -0
  37. package/dist/chunk-BR3SBEFE.cjs +182 -0
  38. package/dist/chunk-BR3SBEFE.cjs.map +1 -0
  39. package/dist/chunk-CVV4HROS.cjs +37 -0
  40. package/dist/chunk-CVV4HROS.cjs.map +1 -0
  41. package/dist/chunk-DCTDH77P.cjs +277 -0
  42. package/dist/chunk-DCTDH77P.cjs.map +1 -0
  43. package/dist/chunk-EBCZUGUX.js +35 -0
  44. package/dist/chunk-EBCZUGUX.js.map +1 -0
  45. package/dist/chunk-EY5LALX2.cjs +26 -0
  46. package/dist/chunk-EY5LALX2.cjs.map +1 -0
  47. package/dist/chunk-FBQHHAL5.js +40 -0
  48. package/dist/chunk-FBQHHAL5.js.map +1 -0
  49. package/dist/chunk-GF4XZK5N.cjs +43 -0
  50. package/dist/chunk-GF4XZK5N.cjs.map +1 -0
  51. package/dist/chunk-GNPQB3MT.js +27 -0
  52. package/dist/chunk-GNPQB3MT.js.map +1 -0
  53. package/dist/chunk-GO6SOMGL.js +181 -0
  54. package/dist/chunk-GO6SOMGL.js.map +1 -0
  55. package/dist/chunk-HCNNMUTR.cjs +36 -0
  56. package/dist/chunk-HCNNMUTR.cjs.map +1 -0
  57. package/dist/chunk-HPVTVQBJ.cjs +238 -0
  58. package/dist/chunk-HPVTVQBJ.cjs.map +1 -0
  59. package/dist/chunk-HYUGRMCY.cjs +247 -0
  60. package/dist/chunk-HYUGRMCY.cjs.map +1 -0
  61. package/dist/chunk-IJMQCOBC.js +34 -0
  62. package/dist/chunk-IJMQCOBC.js.map +1 -0
  63. package/dist/chunk-IY3VNVXD.cjs +183 -0
  64. package/dist/chunk-IY3VNVXD.cjs.map +1 -0
  65. package/dist/chunk-JKFIB6SQ.cjs +685 -0
  66. package/dist/chunk-JKFIB6SQ.cjs.map +1 -0
  67. package/dist/chunk-JLNOESHX.cjs +47 -0
  68. package/dist/chunk-JLNOESHX.cjs.map +1 -0
  69. package/dist/chunk-JURD5MC3.js +178 -0
  70. package/dist/chunk-JURD5MC3.js.map +1 -0
  71. package/dist/chunk-LV3ZWNDC.js +75 -0
  72. package/dist/chunk-LV3ZWNDC.js.map +1 -0
  73. package/dist/chunk-LZ6A6J2E.cjs +77 -0
  74. package/dist/chunk-LZ6A6J2E.cjs.map +1 -0
  75. package/dist/chunk-OKVYLO6C.js +108 -0
  76. package/dist/chunk-OKVYLO6C.js.map +1 -0
  77. package/dist/chunk-PD3LJYS2.js +218 -0
  78. package/dist/chunk-PD3LJYS2.js.map +1 -0
  79. package/dist/chunk-PV4HIVW2.js +130 -0
  80. package/dist/chunk-PV4HIVW2.js.map +1 -0
  81. package/dist/chunk-R7PD3BRA.js +261 -0
  82. package/dist/chunk-R7PD3BRA.js.map +1 -0
  83. package/dist/chunk-SAEG42HW.js +64 -0
  84. package/dist/chunk-SAEG42HW.js.map +1 -0
  85. package/dist/chunk-TIIRBQUA.cjs +110 -0
  86. package/dist/chunk-TIIRBQUA.cjs.map +1 -0
  87. package/dist/chunk-TNJWOHPM.js +948 -0
  88. package/dist/chunk-TNJWOHPM.js.map +1 -0
  89. package/dist/chunk-TXFQ4YIK.js +31 -0
  90. package/dist/chunk-TXFQ4YIK.js.map +1 -0
  91. package/dist/chunk-U5SE6W5M.cjs +158 -0
  92. package/dist/chunk-U5SE6W5M.cjs.map +1 -0
  93. package/dist/chunk-UABYNGBZ.js +39 -0
  94. package/dist/chunk-UABYNGBZ.js.map +1 -0
  95. package/dist/chunk-UXF53ZOV.js +220 -0
  96. package/dist/chunk-UXF53ZOV.js.map +1 -0
  97. package/dist/chunk-VAOCYA6B.js +20 -0
  98. package/dist/chunk-VAOCYA6B.js.map +1 -0
  99. package/dist/chunk-VS5PM7KL.js +45 -0
  100. package/dist/chunk-VS5PM7KL.js.map +1 -0
  101. package/dist/chunk-WQ7EZWBF.js +24 -0
  102. package/dist/chunk-WQ7EZWBF.js.map +1 -0
  103. package/dist/chunk-XFC52BJV.cjs +952 -0
  104. package/dist/chunk-XFC52BJV.cjs.map +1 -0
  105. package/dist/chunk-XPDEQND7.cjs +4 -0
  106. package/dist/chunk-XPDEQND7.cjs.map +1 -0
  107. package/dist/chunk-XUDMML5C.cjs +211 -0
  108. package/dist/chunk-XUDMML5C.cjs.map +1 -0
  109. package/dist/chunk-YPCD7M2N.cjs +22 -0
  110. package/dist/chunk-YPCD7M2N.cjs.map +1 -0
  111. package/dist/chunk-YUEYMIMI.cjs +67 -0
  112. package/dist/chunk-YUEYMIMI.cjs.map +1 -0
  113. package/dist/chunk-YXCVNX2Q.cjs +36 -0
  114. package/dist/chunk-YXCVNX2Q.cjs.map +1 -0
  115. package/dist/chunk-ZEMKE6DI.js +681 -0
  116. package/dist/chunk-ZEMKE6DI.js.map +1 -0
  117. package/dist/dataScience/index.cjs +8 -412
  118. package/dist/dataScience/index.cjs.map +1 -1
  119. package/dist/dataScience/index.js +2 -391
  120. package/dist/dataScience/index.js.map +1 -1
  121. package/dist/domain/permissions/index.cjs +131 -2
  122. package/dist/domain/permissions/index.cjs.map +1 -1
  123. package/dist/domain/permissions/index.d.cts +108 -2
  124. package/dist/domain/permissions/index.d.ts +108 -2
  125. package/dist/domain/permissions/index.js +106 -3
  126. package/dist/domain/permissions/index.js.map +1 -1
  127. package/dist/editor/index.cjs +5 -264
  128. package/dist/editor/index.cjs.map +1 -1
  129. package/dist/editor/index.js +2 -264
  130. package/dist/editor/index.js.map +1 -1
  131. package/dist/encryption/index.cjs +5 -190
  132. package/dist/encryption/index.cjs.map +1 -1
  133. package/dist/encryption/index.js +2 -190
  134. package/dist/encryption/index.js.map +1 -1
  135. package/dist/import/index.cjs +5 -196
  136. package/dist/import/index.cjs.map +1 -1
  137. package/dist/import/index.js +2 -196
  138. package/dist/import/index.js.map +1 -1
  139. package/dist/index.cjs +334 -3752
  140. package/dist/index.cjs.map +1 -1
  141. package/dist/index.d.cts +1814 -104
  142. package/dist/index.d.ts +1814 -104
  143. package/dist/index.js +176 -3627
  144. package/dist/index.js.map +1 -1
  145. package/dist/management/index.cjs +10 -881
  146. package/dist/management/index.cjs.map +1 -1
  147. package/dist/management/index.js +3 -880
  148. package/dist/management/index.js.map +1 -1
  149. package/dist/metastore/index.cjs +5 -337
  150. package/dist/metastore/index.cjs.map +1 -1
  151. package/dist/metastore/index.js +2 -337
  152. package/dist/metastore/index.js.map +1 -1
  153. package/dist/oauth/index.cjs +5 -226
  154. package/dist/oauth/index.cjs.map +1 -1
  155. package/dist/oauth/index.js +2 -226
  156. package/dist/oauth/index.js.map +1 -1
  157. package/dist/project-Bzslbq4u.d.ts +16 -0
  158. package/dist/project-CYhB6rYN.d.cts +16 -0
  159. package/dist/queryService/index.cjs +5 -248
  160. package/dist/queryService/index.cjs.map +1 -1
  161. package/dist/queryService/index.js +2 -248
  162. package/dist/queryService/index.js.map +1 -1
  163. package/dist/queue/index.cjs +5 -190
  164. package/dist/queue/index.cjs.map +1 -1
  165. package/dist/queue/index.js +2 -190
  166. package/dist/queue/index.js.map +1 -1
  167. package/dist/sdk/configurations/index.d.cts +2 -12
  168. package/dist/sdk/configurations/index.d.ts +2 -12
  169. package/dist/sdk/storage/index.cjs +49 -267
  170. package/dist/sdk/storage/index.cjs.map +1 -1
  171. package/dist/sdk/storage/index.d.cts +2 -2
  172. package/dist/sdk/storage/index.d.ts +2 -2
  173. package/dist/sdk/storage/index.js +1 -259
  174. package/dist/sdk/storage/index.js.map +1 -1
  175. package/dist/sdk/tag/index.cjs +6 -203
  176. package/dist/sdk/tag/index.cjs.map +1 -1
  177. package/dist/sdk/tag/index.js +2 -206
  178. package/dist/sdk/tag/index.js.map +1 -1
  179. package/dist/status/index.cjs +6 -176
  180. package/dist/status/index.cjs.map +1 -1
  181. package/dist/status/index.js +3 -176
  182. package/dist/status/index.js.map +1 -1
  183. package/dist/status/types.cjs +2 -0
  184. package/dist/status/types.js +1 -1
  185. package/dist/storage/index.cjs +9 -1110
  186. package/dist/storage/index.cjs.map +1 -1
  187. package/dist/storage/index.d.cts +1 -1
  188. package/dist/storage/index.d.ts +1 -1
  189. package/dist/storage/index.js +3 -1110
  190. package/dist/storage/index.js.map +1 -1
  191. package/dist/storage/types.d.cts +39 -2
  192. package/dist/storage/types.d.ts +39 -2
  193. package/dist/{storageClient-DrYOs4Xm.d.ts → storageClient-BgvUM7gy.d.ts} +4 -1
  194. package/dist/{storageClient-DSLTM3Cr.d.cts → storageClient-CDX-GvNV.d.cts} +4 -1
  195. package/dist/{storageSdk-BBqAo0Vx.d.cts → storageSdk-IOIdwqy-.d.cts} +1 -1
  196. package/dist/{storageSdk-ZVmKQQSl.d.ts → storageSdk-qGaWB1dy.d.ts} +1 -1
  197. package/dist/syncActions/index.cjs +5 -364
  198. package/dist/syncActions/index.cjs.map +1 -1
  199. package/dist/syncActions/index.js +2 -345
  200. package/dist/syncActions/index.js.map +1 -1
  201. package/dist/telemetry/index.cjs +5 -187
  202. package/dist/telemetry/index.cjs.map +1 -1
  203. package/dist/telemetry/index.js +2 -187
  204. package/dist/telemetry/index.js.map +1 -1
  205. package/dist/vault/index.cjs +5 -219
  206. package/dist/vault/index.cjs.map +1 -1
  207. package/dist/vault/index.js +2 -219
  208. package/dist/vault/index.js.map +1 -1
  209. package/dist/verify/index.cjs +5 -184
  210. package/dist/verify/index.cjs.map +1 -1
  211. package/dist/verify/index.js +2 -184
  212. package/dist/verify/index.js.map +1 -1
  213. package/package.json +1 -1
@@ -0,0 +1,33 @@
1
+ 'use strict';
2
+
3
+ var chunkHPVTVQBJ_cjs = require('./chunk-HPVTVQBJ.cjs');
4
+
5
+ // src/clients/telemetry/provisioning/provisioning.ts
6
+ var createProvisioning = (client) => {
7
+ const createCredentials = async (body, signal) => {
8
+ const { data } = await client.post(
9
+ "/provisioning/workspace",
10
+ { body },
11
+ { signal }
12
+ );
13
+ return data;
14
+ };
15
+ return {
16
+ createCredentials
17
+ };
18
+ };
19
+
20
+ // src/clients/telemetry/telemetryClient.ts
21
+ var createTelemetryClient = ({ baseUrl, middlewares }) => {
22
+ const client = chunkHPVTVQBJ_cjs.createGenericFetchClient({
23
+ baseUrl: chunkHPVTVQBJ_cjs.normalizeBaseUrl(baseUrl),
24
+ middlewares
25
+ });
26
+ return {
27
+ provisioning: createProvisioning(client)
28
+ };
29
+ };
30
+
31
+ exports.createTelemetryClient = createTelemetryClient;
32
+ //# sourceMappingURL=chunk-BGLICNTG.cjs.map
33
+ //# sourceMappingURL=chunk-BGLICNTG.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/clients/telemetry/provisioning/provisioning.ts","../src/clients/telemetry/telemetryClient.ts"],"names":["createGenericFetchClient","normalizeBaseUrl"],"mappings":";;;;;AAIO,IAAM,kBAAA,GAAqB,CAAC,MAAA,KAA+B;AAChE,EAAA,MAAM,iBAAA,GAAoB,OAAO,IAAA,EAA6B,MAAA,KAAyB;AACrF,IAAA,MAAM,EAAE,IAAA,EAAK,GAAI,MAAM,MAAA,CAAO,IAAA;AAAA,MAC5B,yBAAA;AAAA,MACA,EAAE,IAAA,EAAK;AAAA,MACP,EAAE,MAAA;AAAO,KACX;AAEA,IAAA,OAAO,IAAA;AAAA,EACT,CAAA;AAEA,EAAA,OAAO;AAAA,IACL;AAAA,GACF;AACF,CAAA;;;ACVO,IAAM,qBAAA,GAAwB,CAAC,EAAE,OAAA,EAAS,aAAY,KAAyB;AACpF,EAAA,MAAM,SAASA,0CAAA,CAAyB;AAAA,IACtC,OAAA,EAASC,mCAAiB,OAAO,CAAA;AAAA,IACjC;AAAA,GACD,CAAA;AAED,EAAA,OAAO;AAAA,IACL,YAAA,EAAc,mBAAmB,MAAM;AAAA,GACzC;AACF","file":"chunk-BGLICNTG.cjs","sourcesContent":["import type { GenericFetchClient } from '../telemetryClient';\n\nimport type { CreateCredentialsBody, WorkspaceData } from './types';\n\nexport const createProvisioning = (client: GenericFetchClient) => {\n const createCredentials = async (body: CreateCredentialsBody, signal?: AbortSignal) => {\n const { data } = await client.post<WorkspaceData, void, void, CreateCredentialsBody>(\n '/provisioning/workspace',\n { body },\n { signal },\n );\n\n return data;\n };\n\n return {\n createCredentials,\n };\n};\n","import { createGenericFetchClient } from '../../fetchClient';\nimport { normalizeBaseUrl } from '../../utils/normalizeBaseUrl';\nimport type { ClientInitOptions } from '../types';\n\nimport { createProvisioning } from './provisioning/provisioning';\n\nexport type GenericFetchClient = ReturnType<typeof createGenericFetchClient>;\n\nexport const createTelemetryClient = ({ baseUrl, middlewares }: ClientInitOptions) => {\n const client = createGenericFetchClient({\n baseUrl: normalizeBaseUrl(baseUrl),\n middlewares,\n });\n\n return {\n provisioning: createProvisioning(client),\n };\n};\n"]}
@@ -0,0 +1,182 @@
1
+ 'use strict';
2
+
3
+ var chunkCVV4HROS_cjs = require('./chunk-CVV4HROS.cjs');
4
+
5
+ // src/utils/keboolaUID.ts
6
+ var KEBOOLA_OBJECT_ID_DELIMITER = "--";
7
+ var keboolaUID = {
8
+ serialize: (input) => {
9
+ if (input.uid === "")
10
+ throw new Error("Invalid Keboola Object ID: uid of an object cannot be empty");
11
+ return ["KID", input.projectId, input.type, input.uid].join(KEBOOLA_OBJECT_ID_DELIMITER);
12
+ },
13
+ deserialize: (input) => {
14
+ const [identifier, projectId, type, uid] = input.split(KEBOOLA_OBJECT_ID_DELIMITER);
15
+ if (identifier !== "KID" || !projectId || !type || !uid)
16
+ throw new Error("Invalid Keboola Object ID");
17
+ return {
18
+ projectId: Number(projectId),
19
+ type,
20
+ uid
21
+ };
22
+ }
23
+ };
24
+
25
+ // src/utils/generateUUID.ts
26
+ var generateUUID = () => crypto.randomUUID();
27
+
28
+ // src/sdks/tag/tagSdk.ts
29
+ var ObjectType = {
30
+ TAG: "tag",
31
+ TAG_BINDING: "tag-binding"
32
+ };
33
+ var createTagSdk = ({ metastoreClient }) => {
34
+ const _getTagMetaObjects = async (type, signal) => {
35
+ const response = await metastoreClient.repository.getMetaObjects(
36
+ {
37
+ objectType: type
38
+ },
39
+ signal
40
+ );
41
+ return response.data.map(({ attributes }) => attributes);
42
+ };
43
+ const _getAllTagBindingMapByTagId = async (signal) => {
44
+ const tagBindings = await _getTagMetaObjects(ObjectType.TAG_BINDING, signal);
45
+ return Object.groupBy(tagBindings, (binding) => binding.data.tagUUID);
46
+ };
47
+ const _getTagBindingMapByTagId = async (tagUUIDs, objectId, signal) => {
48
+ const tagBindingMapByTagId = await _getAllTagBindingMapByTagId(signal);
49
+ const objectUID = keboolaUID.serialize(objectId);
50
+ return tagUUIDs.reduce((acc, tagUUID) => {
51
+ if (acc[tagUUID]) return acc;
52
+ const tagBindings = tagBindingMapByTagId[tagUUID] ?? [];
53
+ acc[tagUUID] = tagBindings.find((binding) => binding.data.objectUID === objectUID) ?? null;
54
+ return acc;
55
+ }, {});
56
+ };
57
+ const _deleteTagBindings = async (tagBindings) => {
58
+ await chunkCVV4HROS_cjs.concurrent({
59
+ items: tagBindings,
60
+ process: async (binding) => metastoreClient.repository.deleteMetaObject({
61
+ objectType: ObjectType.TAG_BINDING,
62
+ UUID: binding.uuid
63
+ }),
64
+ concurrency: 5
65
+ });
66
+ };
67
+ const getTags = async (signal) => {
68
+ const [tags, tagBindingMapByTagId] = await Promise.all([
69
+ _getTagMetaObjects(ObjectType.TAG, signal),
70
+ _getAllTagBindingMapByTagId(signal)
71
+ ]);
72
+ return tags.map((tag) => ({
73
+ tag,
74
+ bindings: tagBindingMapByTagId[tag.uuid] ?? []
75
+ }));
76
+ };
77
+ const getTagsByObjectId = async (objectId, signal) => {
78
+ const tags = await getTags(signal);
79
+ const keboolaObjectUID = keboolaUID.serialize(objectId);
80
+ const mapByTagId = tags.reduce((acc, { tag, bindings }) => {
81
+ acc[tag.uuid] = new Set(bindings.map((binding) => binding.data.objectUID));
82
+ return acc;
83
+ }, {});
84
+ return tags.filter(({ tag }) => mapByTagId[tag.uuid]?.has(keboolaObjectUID));
85
+ };
86
+ const createTag = async (data, meta = {}) => {
87
+ const {
88
+ data: { attributes: tag }
89
+ } = await metastoreClient.repository.createMetaObject({
90
+ objectType: ObjectType.TAG,
91
+ data,
92
+ name: generateUUID(),
93
+ ...meta
94
+ });
95
+ return tag;
96
+ };
97
+ const updateTag = async (tagUUID, data, meta = {}) => {
98
+ const {
99
+ data: { attributes: tag }
100
+ } = await metastoreClient.repository.updateMetaObject({
101
+ objectType: ObjectType.TAG,
102
+ UUID: tagUUID,
103
+ data,
104
+ ...meta
105
+ });
106
+ return tag;
107
+ };
108
+ const deleteTag = async (tagUUID) => {
109
+ const allBindings = await _getTagMetaObjects(ObjectType.TAG_BINDING);
110
+ const tagBindings = allBindings.filter(({ data }) => data.tagUUID === tagUUID);
111
+ await Promise.all([
112
+ // delete tag itself
113
+ metastoreClient.repository.deleteMetaObject({
114
+ objectType: ObjectType.TAG,
115
+ UUID: tagUUID
116
+ }),
117
+ // delete all tag associations
118
+ _deleteTagBindings(tagBindings)
119
+ ]);
120
+ };
121
+ const assignTags = async (tagUUIDs, objectId, meta = {}) => {
122
+ const tagBindingMapByTagId = await _getTagBindingMapByTagId(tagUUIDs, objectId);
123
+ const unassignedTagUUIDs = tagUUIDs.filter((tagUUID) => tagBindingMapByTagId[tagUUID] === null);
124
+ await chunkCVV4HROS_cjs.concurrent({
125
+ items: unassignedTagUUIDs,
126
+ process: async (tagUUID) => metastoreClient.repository.createMetaObject({
127
+ objectType: ObjectType.TAG_BINDING,
128
+ data: {
129
+ objectUID: keboolaUID.serialize(objectId),
130
+ tagUUID
131
+ },
132
+ name: generateUUID(),
133
+ ...meta
134
+ }),
135
+ concurrency: 5
136
+ });
137
+ };
138
+ const unassignTags = async (tagUUIDs, objectID) => {
139
+ const tagBindingMapByTagId = await _getTagBindingMapByTagId(tagUUIDs, objectID);
140
+ const assignedTagUUIDs = tagUUIDs.filter((tagUUID) => tagBindingMapByTagId[tagUUID] !== null);
141
+ const tagBindings = assignedTagUUIDs.map((tagUUID) => tagBindingMapByTagId[tagUUID]);
142
+ await chunkCVV4HROS_cjs.concurrent({
143
+ items: tagBindings,
144
+ process: async (tagBinding) => metastoreClient.repository.deleteMetaObject({
145
+ objectType: ObjectType.TAG_BINDING,
146
+ UUID: tagBinding.uuid
147
+ }),
148
+ concurrency: 5
149
+ });
150
+ };
151
+ const unassignAllTags = async (objectID, signal) => {
152
+ const tagBindings = await _getTagMetaObjects(ObjectType.TAG_BINDING, signal);
153
+ const objectsTagBindings = tagBindings.filter(
154
+ ({ data }) => data.objectUID === keboolaUID.serialize(objectID)
155
+ );
156
+ await _deleteTagBindings(objectsTagBindings);
157
+ };
158
+ const createAndAssignTag = async (data, objectId, meta = {}) => {
159
+ const tag = await createTag(data, meta);
160
+ await assignTags([tag.uuid], objectId, meta);
161
+ return tag;
162
+ };
163
+ return {
164
+ // retrievals
165
+ getTags,
166
+ getTagsByObjectId,
167
+ // modifications
168
+ createTag,
169
+ updateTag,
170
+ deleteTag,
171
+ assignTags,
172
+ unassignTags,
173
+ unassignAllTags,
174
+ createAndAssignTag
175
+ };
176
+ };
177
+
178
+ exports.createTagSdk = createTagSdk;
179
+ exports.generateUUID = generateUUID;
180
+ exports.keboolaUID = keboolaUID;
181
+ //# sourceMappingURL=chunk-BR3SBEFE.cjs.map
182
+ //# sourceMappingURL=chunk-BR3SBEFE.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils/keboolaUID.ts","../src/utils/generateUUID.ts","../src/sdks/tag/tagSdk.ts"],"names":["concurrent"],"mappings":"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","file":"chunk-BR3SBEFE.cjs","sourcesContent":["type KeboolaObjectType =\n | 'data-catalog'\n | 'table'\n | 'bucket'\n | 'flow'\n | 'configuration'\n | 'transformation'\n | 'data-app'\n | 'workspace';\n\nexport type KeboolaObjectId = {\n uid: string;\n type: KeboolaObjectType;\n projectId: number;\n};\n\n//As a delimiter for serialization, we use a double hyphen (--) instead of a single hyphen in type names.\nconst KEBOOLA_OBJECT_ID_DELIMITER = '--';\n\n/**\n * There is a proposal for a string format to identify objects in Keboola.\n *\n * https://keboola.atlassian.net/wiki/spaces/ENGG/pages/3967615431/Keboola+UUID+Format\n * Unfortunately, this format will not pass BE validation as `:` is not allowed in the `uid`, and the length is limited to 50 characters only.\n *\n */\nexport const keboolaUID = {\n serialize: (input: KeboolaObjectId): string => {\n if (input.uid === '')\n throw new Error('Invalid Keboola Object ID: uid of an object cannot be empty');\n\n return ['KID', input.projectId, input.type, input.uid].join(KEBOOLA_OBJECT_ID_DELIMITER);\n },\n\n deserialize: (input: string): KeboolaObjectId => {\n const [identifier, projectId, type, uid] = input.split(KEBOOLA_OBJECT_ID_DELIMITER);\n if (identifier !== 'KID' || !projectId || !type || !uid)\n throw new Error('Invalid Keboola Object ID');\n\n return {\n projectId: Number(projectId),\n type: type as KeboolaObjectType,\n uid,\n };\n },\n};\n","export const generateUUID = () => crypto.randomUUID();\n","import type { MetaObject } from '../../clients/metastore/repository/types';\nimport { concurrent, generateUUID, type KeboolaObjectId, keboolaUID } from '../../utils';\n\nimport type {\n CreateMetaObjectMetaDataInput,\n MetastoreClient,\n TagBindingData,\n TagData,\n TagWithBindings,\n UpdateMetaObjectMetaDataInput,\n} from './types';\n\nconst ObjectType = {\n TAG: 'tag',\n TAG_BINDING: 'tag-binding',\n};\ntype ObjectTypes = (typeof ObjectType)[keyof typeof ObjectType];\n\ntype Options = {\n metastoreClient: MetastoreClient;\n};\n\nexport const createTagSdk = ({ metastoreClient }: Options) => {\n const _getTagMetaObjects = async <T extends Record<string, unknown>>(\n type: ObjectTypes,\n signal?: AbortSignal,\n ) => {\n const response = await metastoreClient.repository.getMetaObjects<T>(\n {\n objectType: type,\n },\n signal,\n );\n return response.data.map(({ attributes }) => attributes);\n };\n\n const _getAllTagBindingMapByTagId = async (signal?: AbortSignal) => {\n const tagBindings = await _getTagMetaObjects<TagBindingData>(ObjectType.TAG_BINDING, signal);\n return Object.groupBy(tagBindings, (binding) => binding.data.tagUUID);\n };\n\n const _getTagBindingMapByTagId = async (\n tagUUIDs: string[],\n objectId: KeboolaObjectId,\n signal?: AbortSignal,\n ) => {\n const tagBindingMapByTagId = await _getAllTagBindingMapByTagId(signal);\n const objectUID = keboolaUID.serialize(objectId);\n return tagUUIDs.reduce<Record<string, MetaObject<TagBindingData> | null>>((acc, tagUUID) => {\n if (acc[tagUUID]) return acc; // filter out duplicated ids\n\n const tagBindings = tagBindingMapByTagId[tagUUID] ?? [];\n acc[tagUUID] = tagBindings.find((binding) => binding.data.objectUID === objectUID) ?? null;\n return acc;\n }, {});\n };\n\n const _deleteTagBindings = async (tagBindings: MetaObject<TagBindingData>[]) => {\n await concurrent({\n items: tagBindings,\n process: async (binding) =>\n metastoreClient.repository.deleteMetaObject({\n objectType: ObjectType.TAG_BINDING,\n UUID: binding.uuid!,\n }),\n concurrency: 5,\n });\n };\n\n const getTags = async (signal?: AbortSignal) => {\n const [tags, tagBindingMapByTagId] = await Promise.all([\n _getTagMetaObjects<TagData>(ObjectType.TAG, signal),\n _getAllTagBindingMapByTagId(signal),\n ]);\n\n return tags.map<TagWithBindings>((tag) => ({\n tag,\n bindings: tagBindingMapByTagId[tag.uuid!] ?? [],\n }));\n };\n\n const getTagsByObjectId = async (objectId: KeboolaObjectId, signal?: AbortSignal) => {\n const tags = await getTags(signal);\n\n const keboolaObjectUID = keboolaUID.serialize(objectId);\n const mapByTagId = tags.reduce<Record<string, Set<string>>>((acc, { tag, bindings }) => {\n acc[tag.uuid!] = new Set(bindings.map((binding) => binding.data.objectUID));\n return acc;\n }, {});\n\n return tags.filter(({ tag }) => mapByTagId[tag.uuid!]?.has(keboolaObjectUID));\n };\n\n const createTag = async (data: TagData, meta: CreateMetaObjectMetaDataInput = {}) => {\n const {\n data: { attributes: tag },\n } = await metastoreClient.repository.createMetaObject({\n objectType: ObjectType.TAG,\n data,\n name: generateUUID(),\n ...meta,\n });\n\n return tag;\n };\n\n const updateTag = async (\n tagUUID: string,\n data: TagData,\n meta: UpdateMetaObjectMetaDataInput = {},\n ) => {\n const {\n data: { attributes: tag },\n } = await metastoreClient.repository.updateMetaObject<TagData>({\n objectType: ObjectType.TAG,\n UUID: tagUUID,\n data,\n ...meta,\n });\n\n return tag;\n };\n\n const deleteTag = async (tagUUID: string) => {\n const allBindings = await _getTagMetaObjects<TagBindingData>(ObjectType.TAG_BINDING);\n const tagBindings = allBindings.filter(({ data }) => data.tagUUID === tagUUID);\n\n await Promise.all([\n // delete tag itself\n metastoreClient.repository.deleteMetaObject({\n objectType: ObjectType.TAG,\n UUID: tagUUID,\n }),\n // delete all tag associations\n _deleteTagBindings(tagBindings),\n ]);\n };\n\n const assignTags = async (\n tagUUIDs: string[],\n objectId: KeboolaObjectId,\n meta: CreateMetaObjectMetaDataInput = {},\n ) => {\n const tagBindingMapByTagId = await _getTagBindingMapByTagId(tagUUIDs, objectId);\n // Assign only the unassigned tag IDs. Ignore the rest.\n const unassignedTagUUIDs = tagUUIDs.filter((tagUUID) => tagBindingMapByTagId[tagUUID] === null);\n\n await concurrent({\n items: unassignedTagUUIDs,\n process: async (tagUUID) =>\n metastoreClient.repository.createMetaObject<TagBindingData>({\n objectType: ObjectType.TAG_BINDING,\n data: {\n objectUID: keboolaUID.serialize(objectId),\n tagUUID: tagUUID,\n },\n name: generateUUID(),\n ...meta,\n }),\n concurrency: 5,\n });\n };\n\n const unassignTags = async (tagUUIDs: string[], objectID: KeboolaObjectId) => {\n const tagBindingMapByTagId = await _getTagBindingMapByTagId(tagUUIDs, objectID);\n const assignedTagUUIDs = tagUUIDs.filter((tagUUID) => tagBindingMapByTagId[tagUUID] !== null);\n\n const tagBindings = assignedTagUUIDs.map((tagUUID) => tagBindingMapByTagId[tagUUID]!);\n\n await concurrent({\n items: tagBindings,\n process: async (tagBinding) =>\n metastoreClient.repository.deleteMetaObject({\n objectType: ObjectType.TAG_BINDING,\n UUID: tagBinding.uuid!,\n }),\n concurrency: 5,\n });\n };\n\n const unassignAllTags = async (objectID: KeboolaObjectId, signal?: AbortSignal) => {\n const tagBindings = await _getTagMetaObjects<TagBindingData>(ObjectType.TAG_BINDING, signal);\n\n const objectsTagBindings = tagBindings.filter(\n ({ data }) => data.objectUID === keboolaUID.serialize(objectID),\n );\n\n await _deleteTagBindings(objectsTagBindings);\n };\n\n const createAndAssignTag = async (\n data: TagData,\n objectId: KeboolaObjectId,\n meta: CreateMetaObjectMetaDataInput = {},\n ) => {\n const tag = await createTag(data, meta);\n await assignTags([tag.uuid!], objectId, meta);\n return tag;\n };\n\n return {\n // retrievals\n getTags,\n getTagsByObjectId,\n\n // modifications\n createTag,\n updateTag,\n deleteTag,\n assignTags,\n unassignTags,\n unassignAllTags,\n createAndAssignTag,\n };\n};\n"]}
@@ -0,0 +1,37 @@
1
+ 'use strict';
2
+
3
+ // src/utils/concurrent.ts
4
+ var concurrent = async ({
5
+ items,
6
+ process,
7
+ concurrency = 2,
8
+ middlewares = []
9
+ }) => {
10
+ if (concurrency < 1) throw new Error("Concurrency must be greater than 0");
11
+ if (items.length === 0) return [];
12
+ if (concurrency === Infinity)
13
+ return Promise.all(items.map((item, index) => process(item, index, items.length)));
14
+ const n = items.length;
15
+ const results = new Array(n);
16
+ const processWithMiddlewares = middlewares.reduceRight(
17
+ (next, middleware) => middleware(next),
18
+ process
19
+ );
20
+ const queue = items.map((item, index) => async () => {
21
+ results[index] = await processWithMiddlewares(item, index, items.length);
22
+ });
23
+ const workers = Array.from(
24
+ { length: Math.min(concurrency, items.length) },
25
+ async function processQueue() {
26
+ while (queue.length) {
27
+ await queue.shift()?.();
28
+ }
29
+ }
30
+ );
31
+ await Promise.all(workers);
32
+ return results;
33
+ };
34
+
35
+ exports.concurrent = concurrent;
36
+ //# sourceMappingURL=chunk-CVV4HROS.cjs.map
37
+ //# sourceMappingURL=chunk-CVV4HROS.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils/concurrent.ts"],"names":[],"mappings":";;;AAgBO,IAAM,aAAa,OAAa;AAAA,EACrC,KAAA;AAAA,EACA,OAAA;AAAA,EACA,WAAA,GAAc,CAAA;AAAA,EACd,cAAc;AAChB,CAAA,KAA6C;AAC3C,EAAA,IAAI,WAAA,GAAc,CAAA,EAAG,MAAM,IAAI,MAAM,oCAAoC,CAAA;AACzE,EAAA,IAAI,KAAA,CAAM,MAAA,KAAW,CAAA,EAAG,OAAO,EAAC;AAChC,EAAA,IAAI,WAAA,KAAgB,QAAA;AAClB,IAAA,OAAO,OAAA,CAAQ,GAAA,CAAI,KAAA,CAAM,GAAA,CAAI,CAAC,IAAA,EAAM,KAAA,KAAU,OAAA,CAAQ,IAAA,EAAM,KAAA,EAAO,KAAA,CAAM,MAAM,CAAC,CAAC,CAAA;AAEnF,EAAA,MAAM,IAAI,KAAA,CAAM,MAAA;AAChB,EAAA,MAAM,OAAA,GAAe,IAAI,KAAA,CAAM,CAAC,CAAA;AAEhC,EAAA,MAAM,yBAAyB,WAAA,CAAY,WAAA;AAAA,IACzC,CAAC,IAAA,EAAM,UAAA,KAAe,UAAA,CAAW,IAAI,CAAA;AAAA,IACrC;AAAA,GACF;AAEA,EAAA,MAAM,QAAQ,KAAA,CAAM,GAAA,CAAI,CAAC,IAAA,EAAM,UAAU,YAAY;AACnD,IAAA,OAAA,CAAQ,KAAK,CAAA,GAAI,MAAM,uBAAuB,IAAA,EAAM,KAAA,EAAO,MAAM,MAAM,CAAA;AAAA,EACzE,CAAC,CAAA;AAED,EAAA,MAAM,UAAU,KAAA,CAAM,IAAA;AAAA,IACpB,EAAE,MAAA,EAAQ,IAAA,CAAK,IAAI,WAAA,EAAa,KAAA,CAAM,MAAM,CAAA,EAAE;AAAA,IAC9C,eAAe,YAAA,GAAe;AAC5B,MAAA,OAAO,MAAM,MAAA,EAAQ;AACnB,QAAA,MAAM,KAAA,CAAM,OAAM,IAAI;AAAA,MACxB;AAAA,IACF;AAAA,GACF;AAEA,EAAA,MAAM,OAAA,CAAQ,IAAI,OAAO,CAAA;AACzB,EAAA,OAAO,OAAA;AACT","file":"chunk-CVV4HROS.cjs","sourcesContent":["type ProcessFn<T, R> = (item: T, index: number, arrayLength: number) => Promise<R>;\nexport type MiddlewareFn<T, R> = (next: ProcessFn<T, R>) => ProcessFn<T, R>;\n\nexport type ConcurrentOptions<T, R> = {\n items: T[];\n process: ProcessFn<T, R>;\n concurrency?: number;\n middlewares?: MiddlewareFn<T, R>[];\n};\n\n/**\n * Executes an asynchronous callback function on an array of items, processing multiple items concurrently with a specified concurrency limit.\n * It behaves similarly to Promise.all(), failing on the first rejected promise.\n * The order of the results matches the order of the promises.\n * The API is the same as Bluebird.map().\n */\nexport const concurrent = async <T, R>({\n items,\n process,\n concurrency = 2,\n middlewares = [],\n}: ConcurrentOptions<T, R>): Promise<R[]> => {\n if (concurrency < 1) throw new Error('Concurrency must be greater than 0');\n if (items.length === 0) return [];\n if (concurrency === Infinity)\n return Promise.all(items.map((item, index) => process(item, index, items.length)));\n\n const n = items.length;\n const results: R[] = new Array(n);\n\n const processWithMiddlewares = middlewares.reduceRight(\n (next, middleware) => middleware(next),\n process,\n );\n\n const queue = items.map((item, index) => async () => {\n results[index] = await processWithMiddlewares(item, index, items.length);\n });\n\n const workers = Array.from(\n { length: Math.min(concurrency, items.length) },\n async function processQueue() {\n while (queue.length) {\n await queue.shift()?.();\n }\n },\n );\n\n await Promise.all(workers);\n return results;\n};\n"]}
@@ -0,0 +1,277 @@
1
+ 'use strict';
2
+
3
+ // src/utils/createAbortError.ts
4
+ var createAbortError = (reason) => new DOMException(reason, "AbortError");
5
+
6
+ // src/utils/delay.ts
7
+ var delay = (timeout, signal) => new Promise((resolve, reject) => {
8
+ if (signal?.aborted) return reject(createAbortError(signal.reason));
9
+ const timeoutId = setTimeout(resolve, timeout);
10
+ signal?.addEventListener(
11
+ "abort",
12
+ () => {
13
+ clearTimeout(timeoutId);
14
+ reject(createAbortError(signal.reason));
15
+ },
16
+ { once: true }
17
+ );
18
+ });
19
+
20
+ // src/utils/poll.ts
21
+ var message = {
22
+ PollPredicateError: "Poll predicate failed",
23
+ PollTimeoutError: "Poll timeout exceeded",
24
+ PollPollTimeoutError: "Poll data failed condition"
25
+ };
26
+ var PollException = class extends Error {
27
+ result;
28
+ constructor(type, result) {
29
+ super(type, { cause: message[type] });
30
+ this.result = result;
31
+ }
32
+ };
33
+ var poll = async ({
34
+ pollFn,
35
+ interval,
36
+ isDone,
37
+ isFailed,
38
+ abortSignal,
39
+ maxAttempts = Infinity
40
+ }) => {
41
+ if (abortSignal?.aborted) throw createAbortError(abortSignal.reason);
42
+ if (interval < 1) throw new Error("Invalid poll interval");
43
+ if (maxAttempts < 1) throw new Error("Invalid poll maxAttempts");
44
+ let callCount = 0;
45
+ while (true) {
46
+ callCount++;
47
+ const data = await pollFn(abortSignal);
48
+ const result = { data, callCount };
49
+ try {
50
+ if (isDone(data)) return result;
51
+ if (isFailed?.(data) ?? false) throw new PollException("PollPollTimeoutError", result);
52
+ } catch (error) {
53
+ if (error instanceof PollException) throw error;
54
+ throw new PollException("PollPredicateError", result);
55
+ }
56
+ if (callCount >= maxAttempts) throw new PollException("PollTimeoutError", result);
57
+ await delay(interval, abortSignal);
58
+ }
59
+ };
60
+
61
+ // src/sdks/storage/storageSdk.ts
62
+ var DEFAULT_POLL_INTERVAL = 2e3;
63
+ var JOB_TERMINAL_STATUSES = /* @__PURE__ */ new Set(["success", "warning", "error", "terminated", "cancelled"]);
64
+ var createStorageSdk = ({ storageClient }) => {
65
+ const waitForJob = async (job, options) => {
66
+ const { data } = await poll({
67
+ pollFn: (abortSignal) => storageClient.jobs.getJob(job.id, abortSignal),
68
+ isDone: (j) => JOB_TERMINAL_STATUSES.has(j.status),
69
+ interval: options?.interval ?? DEFAULT_POLL_INTERVAL,
70
+ maxAttempts: options?.maxAttempts,
71
+ abortSignal: options?.abortSignal
72
+ });
73
+ return data;
74
+ };
75
+ const createTable = async (bucketId, body, options) => {
76
+ const job = await storageClient.tables.createTableAsync(bucketId, body, options?.abortSignal);
77
+ return waitForJob(job, options);
78
+ };
79
+ const importFromFile = async (tableId, body, options) => {
80
+ const job = await storageClient.tables.importAsync(tableId, body, options?.abortSignal);
81
+ return waitForJob(job, options);
82
+ };
83
+ const exportToFile = async (tableId, body, options) => {
84
+ const job = await storageClient.tables.exportAsync(tableId, body, options?.abortSignal);
85
+ return waitForJob(job, options);
86
+ };
87
+ const getBucketListing = async (bucketId, signal) => storageClient.buckets.getListing(bucketId, signal);
88
+ const listBucketListings = async (signal) => storageClient.buckets.listListings(signal);
89
+ const createBucketListing = async (bucketId, input, options) => {
90
+ const job = await storageClient.buckets.createListing(bucketId, input, options?.abortSignal);
91
+ return waitForJob(job, options);
92
+ };
93
+ const updateBucketListing = async (bucketId, input, options) => {
94
+ const job = await storageClient.buckets.updateListing(bucketId, input, options?.abortSignal);
95
+ return waitForJob(job, options);
96
+ };
97
+ const deleteBucketListing = async (bucketId, options) => {
98
+ const job = await storageClient.buckets.deleteListing(bucketId, options?.abortSignal);
99
+ return waitForJob(job, options);
100
+ };
101
+ return {
102
+ createTable,
103
+ importFromFile,
104
+ exportToFile,
105
+ getBucketListing,
106
+ listBucketListings,
107
+ createBucketListing,
108
+ updateBucketListing,
109
+ deleteBucketListing
110
+ };
111
+ };
112
+
113
+ // src/sdks/storage/tableIdParser.ts
114
+ function parseTableId(tableId, defaultStage, defaultBucket) {
115
+ const parts = tableId.match(/^(in|out)?\.(.+)?\.(.+)?$/);
116
+ return {
117
+ stage: parts ? parts[1] || defaultStage : defaultStage,
118
+ bucket: parts ? parts[2] || defaultBucket : defaultBucket,
119
+ table: parts ? parts[3] || "" : ""
120
+ };
121
+ }
122
+ function parse(tableId, options = {}) {
123
+ const parts = parseTableId(
124
+ tableId || "",
125
+ options.defaultStage || "",
126
+ options.defaultBucket || ""
127
+ );
128
+ const { stage, bucket, table } = parts;
129
+ return {
130
+ tableId: `${stage}.${bucket}.${table}`,
131
+ parts,
132
+ setPart: (partNameToSet, value) => {
133
+ const result = ["stage", "bucket", "table"].reduce(
134
+ (memo, partName) => partName === partNameToSet ? `${memo}.${value}` : `${memo}.${parts[partName]}`,
135
+ ""
136
+ ).slice(1);
137
+ return parse(result);
138
+ }
139
+ };
140
+ }
141
+ var tableIdParser = { parse };
142
+
143
+ // src/sdks/storage/tableName.ts
144
+ var stripLegacyBucketPrefix = (bucketName) => {
145
+ if (!bucketName.includes("c-")) {
146
+ return bucketName;
147
+ }
148
+ return bucketName.substring(bucketName.indexOf("c-") + "c-".length);
149
+ };
150
+ var getBucketDisplayNameFromName = (bucketName, options = {}) => {
151
+ if (!bucketName) return "";
152
+ return options.disableLegacyBucketPrefix ? bucketName : stripLegacyBucketPrefix(bucketName);
153
+ };
154
+ var tableNameParsed = (tableId, options = {}) => {
155
+ const { stage, bucket, table } = tableIdParser.parse(tableId).parts;
156
+ const bucketName = options.storageBucket?.displayName ?? getBucketDisplayNameFromName(bucket, options);
157
+ if (stage && bucketName && table) {
158
+ return `${bucketName} / ${table}`;
159
+ }
160
+ return tableId;
161
+ };
162
+
163
+ // src/sdks/storage/fqid.ts
164
+ var FQID_TYPES = {
165
+ organization: "ORG",
166
+ maintainer: "MTR",
167
+ project: "PRJ",
168
+ bucket: "BCT",
169
+ table: "TBL",
170
+ column: "COL",
171
+ config: "CFG",
172
+ component: "CMP",
173
+ externalTable: "EX_TBL",
174
+ externalColumn: "EX_COL"
175
+ };
176
+ var isFQIDType = (value) => {
177
+ return Object.values(FQID_TYPES).includes(value);
178
+ };
179
+ var parseFQID = (fqid) => {
180
+ if (!fqid?.trim()) return {};
181
+ const firstSegment = fqid.split(" ")[0] ?? "";
182
+ const [type, ...rest] = firstSegment.split("/");
183
+ if (!type || !isFQIDType(type)) return {};
184
+ switch (type) {
185
+ case "ORG":
186
+ return { type, organizationId: rest[0] };
187
+ case "MTR":
188
+ return { type, maintainerId: rest[0] };
189
+ case "PRJ":
190
+ return { type, projectId: rest[0] };
191
+ case "BCT":
192
+ return { type, projectId: rest[0], bucketId: rest[1] };
193
+ case "TBL":
194
+ return { type, projectId: rest[0], tableId: rest[1] };
195
+ case "COL":
196
+ return { type, projectId: rest[0], tableId: rest[1], column: rest[2] };
197
+ case "CMP":
198
+ return { type, projectId: rest[0], componentId: rest[1] };
199
+ case "CFG":
200
+ return { type, projectId: rest[0], componentId: rest[1], configId: rest[2] };
201
+ default:
202
+ return {};
203
+ }
204
+ };
205
+ var constructFQID = ({ type, data }) => {
206
+ switch (type) {
207
+ case FQID_TYPES.organization:
208
+ return `ORG/${data.organizationId}`;
209
+ case FQID_TYPES.maintainer:
210
+ return `MTR/${data.maintainerId}`;
211
+ case FQID_TYPES.project:
212
+ return `PRJ/${data.projectId}`;
213
+ case FQID_TYPES.bucket:
214
+ return `BCT/${data.projectId}/${data.bucketId}`;
215
+ case FQID_TYPES.table:
216
+ return `TBL/${data.projectId}/${data.tableId}`;
217
+ case FQID_TYPES.column:
218
+ return `COL/${data.projectId}/${data.tableId}/${data.column}`;
219
+ case FQID_TYPES.component:
220
+ return `CMP/${data.projectId}/${data.componentId}`;
221
+ case FQID_TYPES.config:
222
+ return `CFG/${data.projectId}/${data.componentId}/${data.configId}`;
223
+ }
224
+ };
225
+
226
+ // src/sdks/storage/devBranch.ts
227
+ var parseDevBranchId = (path) => {
228
+ const pathParts = path.split("/");
229
+ const branchKeywordIndex = pathParts.findIndex((pathPart) => pathPart === "branch");
230
+ if (branchKeywordIndex === -1) {
231
+ return null;
232
+ }
233
+ const branchId = pathParts[branchKeywordIndex + 1];
234
+ if (!branchId) {
235
+ return null;
236
+ }
237
+ const branchIdInt = parseInt(branchId, 10);
238
+ if (/^\d+$/.test(branchId) && branchIdInt > 0) {
239
+ return branchIdInt;
240
+ }
241
+ return null;
242
+ };
243
+ var parseCurrentDevBranchIdFromUrl = () => {
244
+ if (typeof location === "undefined") {
245
+ return null;
246
+ }
247
+ return parseDevBranchId(location.pathname);
248
+ };
249
+ var prefixTagsWithDevBranchId = (tags, branchId = null, options = {}) => {
250
+ if (!branchId || options.hasStorageBranches) {
251
+ return tags;
252
+ }
253
+ return tags.map((tag) => `${branchId}-${tag}`);
254
+ };
255
+ var removeBranchFromUrl = (url) => {
256
+ const partToRemove = "branch/\\d+/";
257
+ const regex = new RegExp(partToRemove, "g");
258
+ return url.replace(regex, "");
259
+ };
260
+
261
+ exports.FQID_TYPES = FQID_TYPES;
262
+ exports.PollException = PollException;
263
+ exports.constructFQID = constructFQID;
264
+ exports.createStorageSdk = createStorageSdk;
265
+ exports.delay = delay;
266
+ exports.getBucketDisplayNameFromName = getBucketDisplayNameFromName;
267
+ exports.parse = parse;
268
+ exports.parseCurrentDevBranchIdFromUrl = parseCurrentDevBranchIdFromUrl;
269
+ exports.parseDevBranchId = parseDevBranchId;
270
+ exports.parseFQID = parseFQID;
271
+ exports.poll = poll;
272
+ exports.prefixTagsWithDevBranchId = prefixTagsWithDevBranchId;
273
+ exports.removeBranchFromUrl = removeBranchFromUrl;
274
+ exports.tableIdParser = tableIdParser;
275
+ exports.tableNameParsed = tableNameParsed;
276
+ //# sourceMappingURL=chunk-DCTDH77P.cjs.map
277
+ //# sourceMappingURL=chunk-DCTDH77P.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/utils/createAbortError.ts","../src/utils/delay.ts","../src/utils/poll.ts","../src/sdks/storage/storageSdk.ts","../src/sdks/storage/tableIdParser.ts","../src/sdks/storage/tableName.ts","../src/sdks/storage/fqid.ts","../src/sdks/storage/devBranch.ts"],"names":[],"mappings":"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","file":"chunk-DCTDH77P.cjs","sourcesContent":["export const createAbortError = (reason?: string) => new DOMException(reason, 'AbortError');\n","import { createAbortError } from './createAbortError';\n\nexport const delay = (timeout: number, signal?: AbortSignal) =>\n new Promise((resolve, reject) => {\n if (signal?.aborted) return reject(createAbortError(signal.reason));\n\n const timeoutId = setTimeout(resolve, timeout);\n\n signal?.addEventListener(\n 'abort',\n () => {\n clearTimeout(timeoutId);\n reject(createAbortError(signal.reason));\n },\n { once: true },\n );\n });\n","import { createAbortError } from './createAbortError';\nimport { delay } from './delay';\n\ntype PollResult<T> = {\n data: T;\n callCount: number;\n};\n\ntype PollErrorType = 'PollPredicateError' | 'PollTimeoutError' | 'PollPollTimeoutError';\n\nconst message: Record<PollErrorType, string> = {\n PollPredicateError: 'Poll predicate failed',\n PollTimeoutError: 'Poll timeout exceeded',\n PollPollTimeoutError: 'Poll data failed condition',\n};\n\nexport class PollException<T> extends Error {\n result: PollResult<T>;\n\n constructor(type: PollErrorType, result: PollResult<T>) {\n super(type, { cause: message[type] });\n this.result = result;\n }\n}\n\ntype Options<T> = {\n pollFn: (abortSignal?: AbortSignal) => Promise<T>;\n isDone: (result: T) => boolean;\n isFailed?: (result: T) => boolean;\n interval: number;\n abortSignal?: AbortSignal;\n maxAttempts?: number;\n};\n\nexport const poll = async <T>({\n pollFn,\n interval,\n isDone,\n isFailed,\n abortSignal,\n maxAttempts = Infinity,\n}: Options<T>): Promise<PollResult<T>> => {\n if (abortSignal?.aborted) throw createAbortError(abortSignal.reason);\n if (interval < 1) throw new Error('Invalid poll interval');\n if (maxAttempts < 1) throw new Error('Invalid poll maxAttempts');\n\n let callCount = 0;\n\n while (true) {\n callCount++;\n const data = await pollFn(abortSignal);\n const result = { data, callCount };\n\n try {\n if (isDone(data)) return result;\n if (isFailed?.(data) ?? false) throw new PollException('PollPollTimeoutError', result);\n } catch (error) {\n if (error instanceof PollException) throw error;\n throw new PollException('PollPredicateError', result);\n }\n\n if (callCount >= maxAttempts) throw new PollException('PollTimeoutError', result);\n await delay(interval, abortSignal);\n }\n};\n","import type { createStorageClient } from '../../clients/storage';\nimport type {\n CreateBucketListingInput,\n UpdateBucketListingInput,\n} from '../../clients/storage/buckets/types';\nimport type { Job, JobOperation } from '../../clients/storage/jobs/types';\nimport type {\n CreateTableAsyncBody,\n TableExportAsyncBody,\n TableImportAsyncBody,\n} from '../../clients/storage/tables/types';\nimport { poll } from '../../utils/poll';\n\nconst DEFAULT_POLL_INTERVAL = 2000;\n\nconst JOB_TERMINAL_STATUSES = new Set(['success', 'warning', 'error', 'terminated', 'cancelled']);\n\ntype Options = {\n interval?: number;\n maxAttempts?: number;\n abortSignal?: AbortSignal;\n};\n\ntype StorageSdkOptions = {\n storageClient: ReturnType<typeof createStorageClient>;\n};\n\nexport const createStorageSdk = ({ storageClient }: StorageSdkOptions) => {\n const waitForJob = async <Operation extends JobOperation | string>(\n job: Job<Operation> & { operationName: Operation },\n options?: Options,\n ) => {\n const { data } = await poll({\n pollFn: (abortSignal) => storageClient.jobs.getJob<Operation>(job.id, abortSignal),\n isDone: (j) => JOB_TERMINAL_STATUSES.has(j.status),\n interval: options?.interval ?? DEFAULT_POLL_INTERVAL,\n maxAttempts: options?.maxAttempts,\n abortSignal: options?.abortSignal,\n });\n\n return data;\n };\n\n const createTable = async (bucketId: string, body: CreateTableAsyncBody, options?: Options) => {\n const job = await storageClient.tables.createTableAsync(bucketId, body, options?.abortSignal);\n return waitForJob(job, options);\n };\n\n const importFromFile = async (tableId: string, body: TableImportAsyncBody, options?: Options) => {\n const job = await storageClient.tables.importAsync(tableId, body, options?.abortSignal);\n return waitForJob(job, options);\n };\n\n const exportToFile = async (tableId: string, body?: TableExportAsyncBody, options?: Options) => {\n const job = await storageClient.tables.exportAsync(tableId, body, options?.abortSignal);\n return waitForJob(job, options);\n };\n\n const getBucketListing = async (bucketId: string, signal?: AbortSignal) =>\n storageClient.buckets.getListing(bucketId, signal);\n\n const listBucketListings = async (signal?: AbortSignal) =>\n storageClient.buckets.listListings(signal);\n\n const createBucketListing = async (\n bucketId: string,\n input: CreateBucketListingInput,\n options?: Options,\n ) => {\n const job = await storageClient.buckets.createListing(bucketId, input, options?.abortSignal);\n return waitForJob(job, options);\n };\n\n const updateBucketListing = async (\n bucketId: string,\n input: UpdateBucketListingInput,\n options?: Options,\n ) => {\n const job = await storageClient.buckets.updateListing(bucketId, input, options?.abortSignal);\n return waitForJob(job, options);\n };\n\n const deleteBucketListing = async (bucketId: string, options?: Options) => {\n const job = await storageClient.buckets.deleteListing(bucketId, options?.abortSignal);\n return waitForJob(job, options);\n };\n\n return {\n createTable,\n importFromFile,\n exportToFile,\n getBucketListing,\n listBucketListings,\n createBucketListing,\n updateBucketListing,\n deleteBucketListing,\n };\n};\n","function parseTableId(tableId: string, defaultStage: string, defaultBucket: string) {\n const parts = tableId.match(/^(in|out)?\\.(.+)?\\.(.+)?$/);\n\n return {\n stage: parts ? parts[1] || defaultStage : defaultStage,\n bucket: parts ? parts[2] || defaultBucket : defaultBucket,\n table: parts ? parts[3] || '' : '',\n };\n}\n\nexport function parse(\n tableId: string | null,\n options: { defaultStage?: string; defaultBucket?: string } = {},\n) {\n const parts = parseTableId(\n tableId || '',\n options.defaultStage || '',\n options.defaultBucket || '',\n );\n\n const { stage, bucket, table } = parts;\n return {\n tableId: `${stage}.${bucket}.${table}`,\n parts,\n setPart: (partNameToSet: string, value: string) => {\n const result = (['stage', 'bucket', 'table'] as const)\n .reduce(\n (memo, partName) =>\n partName === partNameToSet ? `${memo}.${value}` : `${memo}.${parts[partName]}`,\n '',\n )\n .slice(1);\n return parse(result);\n },\n };\n}\n\nexport const tableIdParser = { parse };\n","import { tableIdParser } from './tableIdParser';\n\nconst stripLegacyBucketPrefix = (bucketName: string) => {\n if (!bucketName.includes('c-')) {\n return bucketName;\n }\n\n return bucketName.substring(bucketName.indexOf('c-') + 'c-'.length);\n};\n\ntype BucketDisplayNameOptions = {\n disableLegacyBucketPrefix?: boolean;\n};\n\nexport const getBucketDisplayNameFromName = (\n bucketName: string,\n options: BucketDisplayNameOptions = {},\n) => {\n if (!bucketName) return '';\n return options.disableLegacyBucketPrefix ? bucketName : stripLegacyBucketPrefix(bucketName);\n};\n\ntype TableNameParsedOptions = BucketDisplayNameOptions & {\n storageBucket?: { displayName?: string } | null;\n};\n\nexport const tableNameParsed = (tableId: string, options: TableNameParsedOptions = {}) => {\n const { stage, bucket, table } = tableIdParser.parse(tableId).parts;\n const bucketName =\n options.storageBucket?.displayName ?? getBucketDisplayNameFromName(bucket, options);\n\n if (stage && bucketName && table) {\n return `${bucketName} / ${table}`;\n }\n\n return tableId;\n};\n","export const FQID_TYPES = {\n organization: 'ORG',\n maintainer: 'MTR',\n project: 'PRJ',\n bucket: 'BCT',\n table: 'TBL',\n column: 'COL',\n config: 'CFG',\n component: 'CMP',\n externalTable: 'EX_TBL',\n externalColumn: 'EX_COL',\n} as const;\n\ntype FQIDTypes = typeof FQID_TYPES;\n\nexport type ParsedFQID = {\n type?: (typeof FQID_TYPES)[keyof typeof FQID_TYPES];\n organizationId?: string;\n maintainerId?: string;\n projectId?: string;\n bucketId?: string;\n tableId?: string;\n componentId?: string;\n configId?: string;\n column?: string;\n};\n\nconst isFQIDType = (value: string): value is FQIDTypes[keyof FQIDTypes] => {\n return Object.values(FQID_TYPES).includes(value as FQIDTypes[keyof FQIDTypes]);\n};\n\nconst parseFQID = (fqid?: string): ParsedFQID | Record<string, never> => {\n if (!fqid?.trim()) return {};\n\n const firstSegment = fqid.split(' ')[0] ?? '';\n const [type, ...rest] = firstSegment.split('/');\n\n if (!type || !isFQIDType(type)) return {};\n\n switch (type) {\n case 'ORG':\n return { type, organizationId: rest[0] };\n case 'MTR':\n return { type, maintainerId: rest[0] };\n case 'PRJ':\n return { type, projectId: rest[0] };\n case 'BCT':\n return { type, projectId: rest[0], bucketId: rest[1] };\n case 'TBL':\n return { type, projectId: rest[0], tableId: rest[1] };\n case 'COL':\n return { type, projectId: rest[0], tableId: rest[1], column: rest[2] };\n case 'CMP':\n return { type, projectId: rest[0], componentId: rest[1] };\n case 'CFG':\n return { type, projectId: rest[0], componentId: rest[1], configId: rest[2] };\n default:\n return {};\n }\n};\n\ntype FQIDData =\n | {\n type: FQIDTypes['organization'];\n data: { organizationId: string };\n }\n | {\n type: FQIDTypes['maintainer'];\n data: { maintainerId: string };\n }\n | {\n type: FQIDTypes['project'];\n data: { projectId: string };\n }\n | {\n type: FQIDTypes['bucket'];\n data: { projectId: string; bucketId: string };\n }\n | {\n type: FQIDTypes['table'];\n data: { projectId: string; tableId: string };\n }\n | {\n type: FQIDTypes['column'];\n data: { projectId: string; tableId: string; column: string };\n }\n | {\n type: FQIDTypes['component'];\n data: { projectId: string; componentId: string };\n }\n | {\n type: FQIDTypes['config'];\n data: { projectId: string; componentId: string; configId: string };\n };\n\nconst constructFQID = ({ type, data }: FQIDData) => {\n switch (type) {\n case FQID_TYPES.organization:\n return `ORG/${data.organizationId}`;\n case FQID_TYPES.maintainer:\n return `MTR/${data.maintainerId}`;\n case FQID_TYPES.project:\n return `PRJ/${data.projectId}`;\n case FQID_TYPES.bucket:\n return `BCT/${data.projectId}/${data.bucketId}`;\n case FQID_TYPES.table:\n return `TBL/${data.projectId}/${data.tableId}`;\n case FQID_TYPES.column:\n return `COL/${data.projectId}/${data.tableId}/${data.column}`;\n case FQID_TYPES.component:\n return `CMP/${data.projectId}/${data.componentId}`;\n case FQID_TYPES.config:\n return `CFG/${data.projectId}/${data.componentId}/${data.configId}`;\n }\n};\n\nexport { parseFQID, constructFQID };\n","export const parseDevBranchId = (path: string): number | null => {\n const pathParts = path.split('/');\n const branchKeywordIndex = pathParts.findIndex((pathPart) => pathPart === 'branch');\n if (branchKeywordIndex === -1) {\n return null;\n }\n const branchId = pathParts[branchKeywordIndex + 1];\n if (!branchId) {\n return null;\n }\n const branchIdInt = parseInt(branchId, 10);\n if (/^\\d+$/.test(branchId) && branchIdInt > 0) {\n return branchIdInt;\n }\n return null;\n};\n\nexport const parseCurrentDevBranchIdFromUrl = (): number | null => {\n if (typeof location === 'undefined') {\n return null;\n }\n return parseDevBranchId(location.pathname);\n};\n\ntype PrefixTagsOptions = {\n hasStorageBranches?: boolean;\n};\n\nexport const prefixTagsWithDevBranchId = (\n tags: string[],\n branchId: number | string | null = null,\n options: PrefixTagsOptions = {},\n): string[] => {\n if (!branchId || options.hasStorageBranches) {\n return tags;\n }\n\n return tags.map((tag) => `${branchId}-${tag}`);\n};\n\nexport const removeBranchFromUrl = (url: string): string => {\n const partToRemove = 'branch/\\\\d+/'; // This pattern matches \"branch/\" followed by one or more digits\n const regex = new RegExp(partToRemove, 'g');\n\n return url.replace(regex, '');\n};\n"]}
@@ -0,0 +1,35 @@
1
+ // src/utils/concurrent.ts
2
+ var concurrent = async ({
3
+ items,
4
+ process,
5
+ concurrency = 2,
6
+ middlewares = []
7
+ }) => {
8
+ if (concurrency < 1) throw new Error("Concurrency must be greater than 0");
9
+ if (items.length === 0) return [];
10
+ if (concurrency === Infinity)
11
+ return Promise.all(items.map((item, index) => process(item, index, items.length)));
12
+ const n = items.length;
13
+ const results = new Array(n);
14
+ const processWithMiddlewares = middlewares.reduceRight(
15
+ (next, middleware) => middleware(next),
16
+ process
17
+ );
18
+ const queue = items.map((item, index) => async () => {
19
+ results[index] = await processWithMiddlewares(item, index, items.length);
20
+ });
21
+ const workers = Array.from(
22
+ { length: Math.min(concurrency, items.length) },
23
+ async function processQueue() {
24
+ while (queue.length) {
25
+ await queue.shift()?.();
26
+ }
27
+ }
28
+ );
29
+ await Promise.all(workers);
30
+ return results;
31
+ };
32
+
33
+ export { concurrent };
34
+ //# sourceMappingURL=chunk-EBCZUGUX.js.map
35
+ //# sourceMappingURL=chunk-EBCZUGUX.js.map