@keboola/api-client 2.0.0 → 3.0.1

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 (244) hide show
  1. package/README.md +0 -33
  2. package/dist/ai/index.cjs +3 -3
  3. package/dist/ai/index.d.cts +1 -1
  4. package/dist/ai/index.d.ts +1 -1
  5. package/dist/ai/index.js +2 -2
  6. package/dist/assets/index.cjs +3 -3
  7. package/dist/assets/index.d.cts +1 -1
  8. package/dist/assets/index.d.ts +1 -1
  9. package/dist/assets/index.js +2 -2
  10. package/dist/{authMiddleware-BteBe1Bt.d.cts → authMiddleware-CeIxAJQ5.d.cts} +1 -1
  11. package/dist/{authMiddleware-BTFSCMTE.d.ts → authMiddleware-Dcy9gRT9.d.ts} +1 -1
  12. package/dist/chat/index.cjs +3 -3
  13. package/dist/chat/index.d.cts +1 -1
  14. package/dist/chat/index.d.ts +1 -1
  15. package/dist/chat/index.js +2 -2
  16. package/dist/{chunk-R7PD3BRA.js → chunk-2ZMZ4KWJ.js} +3 -23
  17. package/dist/chunk-2ZMZ4KWJ.js.map +1 -0
  18. package/dist/{chunk-VS5PM7KL.js → chunk-3DW7RIEB.js} +4 -4
  19. package/dist/chunk-3DW7RIEB.js.map +1 -0
  20. package/dist/{chunk-633QJMHH.cjs → chunk-4TENBFWN.cjs} +5 -5
  21. package/dist/chunk-4TENBFWN.cjs.map +1 -0
  22. package/dist/{chunk-LZ6A6J2E.cjs → chunk-5DVEQBCD.cjs} +8 -8
  23. package/dist/chunk-5DVEQBCD.cjs.map +1 -0
  24. package/dist/{chunk-3Y6NK7TC.js → chunk-5PUNJJAR.js} +4 -4
  25. package/dist/chunk-5PUNJJAR.js.map +1 -0
  26. package/dist/{chunk-6RQDX6JY.cjs → chunk-5YN6FED2.cjs} +6 -6
  27. package/dist/chunk-5YN6FED2.cjs.map +1 -0
  28. package/dist/{chunk-3T54WH4X.cjs → chunk-6D3MJRXE.cjs} +5 -5
  29. package/dist/chunk-6D3MJRXE.cjs.map +1 -0
  30. package/dist/{chunk-76AHKXLC.cjs → chunk-6FW72PC2.cjs} +9 -9
  31. package/dist/chunk-6FW72PC2.cjs.map +1 -0
  32. package/dist/{chunk-IY3VNVXD.cjs → chunk-6HBXNLB7.cjs} +5 -5
  33. package/dist/chunk-6HBXNLB7.cjs.map +1 -0
  34. package/dist/{chunk-WQ7EZWBF.js → chunk-6TUGEXVX.js} +4 -4
  35. package/dist/chunk-6TUGEXVX.js.map +1 -0
  36. package/dist/{chunk-OKVYLO6C.js → chunk-76Q2CTFV.js} +4 -4
  37. package/dist/chunk-76Q2CTFV.js.map +1 -0
  38. package/dist/chunk-7ETZQGY7.js +75 -0
  39. package/dist/chunk-7ETZQGY7.js.map +1 -0
  40. package/dist/{chunk-EY5LALX2.cjs → chunk-AYXQJONA.cjs} +5 -5
  41. package/dist/chunk-AYXQJONA.cjs.map +1 -0
  42. package/dist/{chunk-YPCD7M2N.cjs → chunk-BA2JMZP6.cjs} +5 -5
  43. package/dist/chunk-BA2JMZP6.cjs.map +1 -0
  44. package/dist/{chunk-SAEG42HW.js → chunk-CQFZ7PGZ.js} +4 -4
  45. package/dist/chunk-CQFZ7PGZ.js.map +1 -0
  46. package/dist/{chunk-JKFIB6SQ.cjs → chunk-D2ZTB5R2.cjs} +33 -35
  47. package/dist/chunk-D2ZTB5R2.cjs.map +1 -0
  48. package/dist/{chunk-YXCVNX2Q.cjs → chunk-ECQZAWH3.cjs} +5 -5
  49. package/dist/chunk-ECQZAWH3.cjs.map +1 -0
  50. package/dist/{chunk-GO6SOMGL.js → chunk-GLQZHLLN.js} +4 -4
  51. package/dist/chunk-GLQZHLLN.js.map +1 -0
  52. package/dist/{chunk-TXFQ4YIK.js → chunk-HLGMFFDF.js} +4 -4
  53. package/dist/chunk-HLGMFFDF.js.map +1 -0
  54. package/dist/{chunk-JLNOESHX.cjs → chunk-IL2PAEG3.cjs} +5 -5
  55. package/dist/chunk-IL2PAEG3.cjs.map +1 -0
  56. package/dist/chunk-IWIN6HKU.cjs +82 -0
  57. package/dist/chunk-IWIN6HKU.cjs.map +1 -0
  58. package/dist/{chunk-HCNNMUTR.cjs → chunk-KOO3ZG5X.cjs} +5 -5
  59. package/dist/chunk-KOO3ZG5X.cjs.map +1 -0
  60. package/dist/{chunk-VAOCYA6B.js → chunk-LBVYZLWL.js} +4 -4
  61. package/dist/chunk-LBVYZLWL.js.map +1 -0
  62. package/dist/{chunk-BGLICNTG.cjs → chunk-LI3BAYDV.cjs} +5 -5
  63. package/dist/chunk-LI3BAYDV.cjs.map +1 -0
  64. package/dist/{chunk-3B7L6MCG.js → chunk-M4PFR3OS.js} +4 -4
  65. package/dist/chunk-M4PFR3OS.js.map +1 -0
  66. package/dist/{chunk-HPVTVQBJ.cjs → chunk-MTFRH3R5.cjs} +4 -22
  67. package/dist/chunk-MTFRH3R5.cjs.map +1 -0
  68. package/dist/{chunk-GNPQB3MT.js → chunk-OAKTIIG4.js} +3 -3
  69. package/dist/chunk-OAKTIIG4.js.map +1 -0
  70. package/dist/{chunk-LV3ZWNDC.js → chunk-PM2FAMWT.js} +4 -4
  71. package/dist/chunk-PM2FAMWT.js.map +1 -0
  72. package/dist/{chunk-PV4HIVW2.js → chunk-Q6T6GRDR.js} +4 -4
  73. package/dist/chunk-Q6T6GRDR.js.map +1 -0
  74. package/dist/{chunk-PD3LJYS2.js → chunk-QXWPUKK2.js} +5 -22
  75. package/dist/chunk-QXWPUKK2.js.map +1 -0
  76. package/dist/{chunk-UXF53ZOV.js → chunk-RBGTWJ7G.js} +4 -4
  77. package/dist/chunk-RBGTWJ7G.js.map +1 -0
  78. package/dist/{chunk-ZEMKE6DI.js → chunk-RBW5ABSQ.js} +24 -26
  79. package/dist/chunk-RBW5ABSQ.js.map +1 -0
  80. package/dist/{chunk-TIIRBQUA.cjs → chunk-REXMA2IN.cjs} +5 -5
  81. package/dist/chunk-REXMA2IN.cjs.map +1 -0
  82. package/dist/{chunk-345V46LR.cjs → chunk-ROBQ2CV7.cjs} +115 -79
  83. package/dist/chunk-ROBQ2CV7.cjs.map +1 -0
  84. package/dist/{chunk-HYUGRMCY.cjs → chunk-RTD3XWBM.cjs} +8 -8
  85. package/dist/chunk-RTD3XWBM.cjs.map +1 -0
  86. package/dist/{chunk-XUDMML5C.cjs → chunk-SDA2UO4X.cjs} +5 -5
  87. package/dist/chunk-SDA2UO4X.cjs.map +1 -0
  88. package/dist/{chunk-FBQHHAL5.js → chunk-T23NVI3Q.js} +4 -4
  89. package/dist/chunk-T23NVI3Q.js.map +1 -0
  90. package/dist/{chunk-4N7XBMWP.js → chunk-T66CY2YX.js} +111 -75
  91. package/dist/chunk-T66CY2YX.js.map +1 -0
  92. package/dist/{chunk-IJMQCOBC.js → chunk-V35JLM5Q.js} +4 -4
  93. package/dist/chunk-V35JLM5Q.js.map +1 -0
  94. package/dist/{chunk-DCTDH77P.cjs → chunk-VLSN55I3.cjs} +2 -24
  95. package/dist/chunk-VLSN55I3.cjs.map +1 -0
  96. package/dist/{chunk-YUEYMIMI.cjs → chunk-ZIVZF6M2.cjs} +6 -6
  97. package/dist/chunk-ZIVZF6M2.cjs.map +1 -0
  98. package/dist/{chunk-7FY6COWG.js → chunk-ZQPET6GI.js} +4 -4
  99. package/dist/chunk-ZQPET6GI.js.map +1 -0
  100. package/dist/{createGenericFetchClient-DEakI3F1.d.ts → createGenericFetchClient-Cp2By_KQ.d.ts} +1 -1
  101. package/dist/{createGenericFetchClient-CLUzu-jY.d.cts → createGenericFetchClient-DuW7iSRy.d.cts} +1 -1
  102. package/dist/{createOpenapiFetchClient-CpXmAIFB.d.cts → createOpenapiFetchClient-BuKDZcLD.d.cts} +1 -1
  103. package/dist/{createOpenapiFetchClient-_sm4bchL.d.ts → createOpenapiFetchClient-DhL2gQvd.d.ts} +1 -1
  104. package/dist/dataScience/index.cjs +4 -4
  105. package/dist/dataScience/index.d.cts +1 -1
  106. package/dist/dataScience/index.d.ts +1 -1
  107. package/dist/dataScience/index.js +2 -2
  108. package/dist/domain/storageTable/index.cjs +267 -0
  109. package/dist/domain/storageTable/index.cjs.map +1 -0
  110. package/dist/domain/storageTable/index.d.cts +131 -0
  111. package/dist/domain/storageTable/index.d.ts +131 -0
  112. package/dist/domain/storageTable/index.js +264 -0
  113. package/dist/domain/storageTable/index.js.map +1 -0
  114. package/dist/editor/index.cjs +3 -3
  115. package/dist/editor/index.d.cts +2 -2
  116. package/dist/editor/index.d.ts +2 -2
  117. package/dist/editor/index.js +2 -2
  118. package/dist/editor/types.d.cts +1 -1
  119. package/dist/editor/types.d.ts +1 -1
  120. package/dist/encryption/index.cjs +3 -3
  121. package/dist/encryption/index.d.cts +1 -1
  122. package/dist/encryption/index.d.ts +1 -1
  123. package/dist/encryption/index.js +2 -2
  124. package/dist/import/index.cjs +3 -3
  125. package/dist/import/index.d.cts +1 -1
  126. package/dist/import/index.d.ts +1 -1
  127. package/dist/import/index.js +2 -2
  128. package/dist/index.cjs +316 -182
  129. package/dist/index.cjs.map +1 -1
  130. package/dist/index.d.cts +113 -27
  131. package/dist/index.d.ts +113 -27
  132. package/dist/index.js +287 -150
  133. package/dist/index.js.map +1 -1
  134. package/dist/management/index.cjs +5 -5
  135. package/dist/management/index.d.cts +5 -5
  136. package/dist/management/index.d.ts +5 -5
  137. package/dist/management/index.js +3 -3
  138. package/dist/metastore/index.cjs +3 -3
  139. package/dist/metastore/index.d.cts +2 -2
  140. package/dist/metastore/index.d.ts +2 -2
  141. package/dist/metastore/index.js +2 -2
  142. package/dist/oauth/index.cjs +3 -3
  143. package/dist/oauth/index.d.cts +1 -1
  144. package/dist/oauth/index.d.ts +1 -1
  145. package/dist/oauth/index.js +2 -2
  146. package/dist/queryService/index.cjs +3 -3
  147. package/dist/queryService/index.d.cts +1 -1
  148. package/dist/queryService/index.d.ts +1 -1
  149. package/dist/queryService/index.js +2 -2
  150. package/dist/queue/index.cjs +3 -3
  151. package/dist/queue/index.d.cts +1 -1
  152. package/dist/queue/index.d.ts +1 -1
  153. package/dist/queue/index.js +2 -2
  154. package/dist/sdk/storage/index.cjs +11 -19
  155. package/dist/sdk/storage/index.d.cts +6 -17
  156. package/dist/sdk/storage/index.d.ts +6 -17
  157. package/dist/sdk/storage/index.js +1 -1
  158. package/dist/sdk/tag/index.d.cts +2 -2
  159. package/dist/sdk/tag/index.d.ts +2 -2
  160. package/dist/sdk/tag/types.d.cts +2 -2
  161. package/dist/sdk/tag/types.d.ts +2 -2
  162. package/dist/sdk/vault/index.cjs +33 -0
  163. package/dist/sdk/vault/index.cjs.map +1 -0
  164. package/dist/sdk/vault/index.d.cts +70 -0
  165. package/dist/sdk/vault/index.d.ts +70 -0
  166. package/dist/sdk/vault/index.js +4 -0
  167. package/dist/sdk/vault/index.js.map +1 -0
  168. package/dist/status/index.cjs +3 -3
  169. package/dist/status/index.d.cts +1 -1
  170. package/dist/status/index.d.ts +1 -1
  171. package/dist/status/index.js +2 -2
  172. package/dist/storage/index.cjs +4 -4
  173. package/dist/storage/index.d.cts +4 -4
  174. package/dist/storage/index.d.ts +4 -4
  175. package/dist/storage/index.js +2 -2
  176. package/dist/storage/types.d.cts +59 -2
  177. package/dist/storage/types.d.ts +59 -2
  178. package/dist/{storageClient-CmK1LPHr.d.cts → storageClient-C5R3H96R.d.cts} +7 -4
  179. package/dist/{storageClient-BicsbzZy.d.ts → storageClient-DBiS4voo.d.ts} +7 -4
  180. package/dist/{storageSdk-BZ7ZW6_h.d.cts → storageSdk-B7Iq38Vh.d.cts} +1 -1
  181. package/dist/{storageSdk-DCcD68FQ.d.ts → storageSdk-BnIemr2s.d.ts} +1 -1
  182. package/dist/syncActions/index.cjs +3 -3
  183. package/dist/syncActions/index.d.cts +2 -2
  184. package/dist/syncActions/index.d.ts +2 -2
  185. package/dist/syncActions/index.js +2 -2
  186. package/dist/telemetry/index.cjs +3 -3
  187. package/dist/telemetry/index.d.cts +2 -2
  188. package/dist/telemetry/index.d.ts +2 -2
  189. package/dist/telemetry/index.js +2 -2
  190. package/dist/{types-DgaMV8FF.d.ts → types-Bom8wyth.d.cts} +1 -13
  191. package/dist/{types-DgaMV8FF.d.cts → types-Bom8wyth.d.ts} +1 -13
  192. package/dist/types-Brx8PoEB.d.cts +11 -0
  193. package/dist/{types-B--u7l2H.d.ts → types-CqWXdTMg.d.ts} +0 -19
  194. package/dist/types-D4CDCW-Y.d.ts +11 -0
  195. package/dist/{types-C0Owx2P7.d.cts → types-DBVQGCI1.d.cts} +0 -19
  196. package/dist/vault/index.cjs +3 -3
  197. package/dist/vault/index.d.cts +1 -1
  198. package/dist/vault/index.d.ts +1 -1
  199. package/dist/vault/index.js +2 -2
  200. package/dist/vault/types.d.cts +3 -2
  201. package/dist/vault/types.d.ts +3 -2
  202. package/dist/verify/index.cjs +3 -3
  203. package/dist/verify/index.js +2 -2
  204. package/package.json +29 -3
  205. package/dist/chunk-345V46LR.cjs.map +0 -1
  206. package/dist/chunk-3B7L6MCG.js.map +0 -1
  207. package/dist/chunk-3T54WH4X.cjs.map +0 -1
  208. package/dist/chunk-3Y6NK7TC.js.map +0 -1
  209. package/dist/chunk-4N7XBMWP.js.map +0 -1
  210. package/dist/chunk-633QJMHH.cjs.map +0 -1
  211. package/dist/chunk-6RQDX6JY.cjs.map +0 -1
  212. package/dist/chunk-76AHKXLC.cjs.map +0 -1
  213. package/dist/chunk-7FY6COWG.js.map +0 -1
  214. package/dist/chunk-BGLICNTG.cjs.map +0 -1
  215. package/dist/chunk-DCTDH77P.cjs.map +0 -1
  216. package/dist/chunk-EY5LALX2.cjs.map +0 -1
  217. package/dist/chunk-FBQHHAL5.js.map +0 -1
  218. package/dist/chunk-GNPQB3MT.js.map +0 -1
  219. package/dist/chunk-GO6SOMGL.js.map +0 -1
  220. package/dist/chunk-HCNNMUTR.cjs.map +0 -1
  221. package/dist/chunk-HPVTVQBJ.cjs.map +0 -1
  222. package/dist/chunk-HYUGRMCY.cjs.map +0 -1
  223. package/dist/chunk-IJMQCOBC.js.map +0 -1
  224. package/dist/chunk-IY3VNVXD.cjs.map +0 -1
  225. package/dist/chunk-JKFIB6SQ.cjs.map +0 -1
  226. package/dist/chunk-JLNOESHX.cjs.map +0 -1
  227. package/dist/chunk-LV3ZWNDC.js.map +0 -1
  228. package/dist/chunk-LZ6A6J2E.cjs.map +0 -1
  229. package/dist/chunk-OKVYLO6C.js.map +0 -1
  230. package/dist/chunk-PD3LJYS2.js.map +0 -1
  231. package/dist/chunk-PV4HIVW2.js.map +0 -1
  232. package/dist/chunk-R7PD3BRA.js.map +0 -1
  233. package/dist/chunk-SAEG42HW.js.map +0 -1
  234. package/dist/chunk-TIIRBQUA.cjs.map +0 -1
  235. package/dist/chunk-TXFQ4YIK.js.map +0 -1
  236. package/dist/chunk-UXF53ZOV.js.map +0 -1
  237. package/dist/chunk-VAOCYA6B.js.map +0 -1
  238. package/dist/chunk-VS5PM7KL.js.map +0 -1
  239. package/dist/chunk-WQ7EZWBF.js.map +0 -1
  240. package/dist/chunk-XUDMML5C.cjs.map +0 -1
  241. package/dist/chunk-YPCD7M2N.cjs.map +0 -1
  242. package/dist/chunk-YUEYMIMI.cjs.map +0 -1
  243. package/dist/chunk-YXCVNX2Q.cjs.map +0 -1
  244. package/dist/chunk-ZEMKE6DI.js.map +0 -1
@@ -0,0 +1,267 @@
1
+ 'use strict';
2
+
3
+ var zod = require('zod');
4
+
5
+ // src/domain/storageTable/constants.ts
6
+ var BRANCH_PREFIX_REGEX = /^(\d+)-(.+)$/;
7
+ var LEGACY_BUCKET_PREFIX = "c-";
8
+ var NAME_CHARSET_REGEX = /^[a-zA-Z0-9_-]+$/;
9
+ var NAME_MAX_LENGTH = 96;
10
+ var stageSchema = zod.z.enum(["in", "out"]);
11
+ var nameSchema = zod.z.string().min(1, `Invalid name segment: must not be empty`).max(NAME_MAX_LENGTH, `Invalid name segment: exceeds ${NAME_MAX_LENGTH} characters`).refine((n) => !n.startsWith("_"), `Invalid name segment: must not start with an underscore`).regex(NAME_CHARSET_REGEX, `Invalid name segment: contains invalid characters`);
12
+ var tableIdSchema = zod.z.string().refine(
13
+ (id) => id.split(".").length === 3,
14
+ 'Invalid table id: must be in "{stage}.{bucket}.{table}" form'
15
+ ).transform((id) => id.split(".")).pipe(zod.z.tuple([stageSchema, nameSchema, nameSchema]));
16
+ var bucketIdSchema = zod.z.string().refine(
17
+ (id) => id.split(".").length === 2,
18
+ 'Invalid bucket id: must be in "{stage}.{bucket}" form'
19
+ ).transform((id) => id.split(".")).pipe(zod.z.tuple([stageSchema, nameSchema]));
20
+
21
+ // src/domain/storageTable/codec.ts
22
+ var createBucketCodec = ({
23
+ useLegacyBucketPrefix,
24
+ hasProtectedDefaultBranch,
25
+ hasStorageBranches
26
+ }) => {
27
+ const decode = (name) => {
28
+ const hasLegacyPrefix = useLegacyBucketPrefix && name.startsWith(LEGACY_BUCKET_PREFIX);
29
+ const stripped = hasLegacyPrefix ? name.slice(LEGACY_BUCKET_PREFIX.length) : name;
30
+ if (hasProtectedDefaultBranch || hasStorageBranches)
31
+ return {
32
+ kind: "storage-branch",
33
+ baseName: stripped,
34
+ hasLegacyPrefix
35
+ };
36
+ const branchMatch = BRANCH_PREFIX_REGEX.exec(stripped);
37
+ return {
38
+ kind: "legacy",
39
+ hasLegacyPrefix,
40
+ branchId: branchMatch?.[1] ?? null,
41
+ baseName: branchMatch?.[2] ?? stripped
42
+ };
43
+ };
44
+ const encode = (bucket) => {
45
+ const stageResult = stageSchema.safeParse(bucket.stage);
46
+ if (!stageResult.success) return { success: false, error: stageResult.error };
47
+ const prefix = bucket.hasLegacyPrefix ? LEGACY_BUCKET_PREFIX : "";
48
+ const baseNameResult = nameSchema.safeParse(bucket.baseName);
49
+ if (!baseNameResult.success) return { success: false, error: baseNameResult.error };
50
+ if (bucket.kind === "storage-branch") {
51
+ const prefixedName2 = `${prefix}${bucket.baseName}`;
52
+ return {
53
+ success: true,
54
+ data: {
55
+ kind: "storage-branch",
56
+ id: `${bucket.stage}.${prefixedName2}`,
57
+ prefixedName: prefixedName2
58
+ }
59
+ };
60
+ }
61
+ const branch = bucket.branchId ? `${bucket.branchId}-` : "";
62
+ const branchedName = `${branch}${bucket.baseName}`;
63
+ const prefixedName = `${prefix}${branchedName}`;
64
+ return {
65
+ success: true,
66
+ data: {
67
+ kind: "legacy",
68
+ id: `${bucket.stage}.${prefixedName}`,
69
+ prefixedName,
70
+ branchedName
71
+ }
72
+ };
73
+ };
74
+ return { decode, encode };
75
+ };
76
+
77
+ // src/domain/storageTable/model.ts
78
+ var createTableModel = (options) => {
79
+ const codec = createBucketCodec(options);
80
+ const decodeTable = (stage, bucketName, tableName) => ({
81
+ name: tableName,
82
+ bucket: { ...codec.decode(bucketName), stage }
83
+ });
84
+ const serializeBucketDisplayName = (bucket) => {
85
+ const result = codec.encode(bucket);
86
+ if (!result.success) throw result.error;
87
+ return result.data.kind === "storage-branch" ? bucket.baseName : result.data.branchedName;
88
+ };
89
+ const serializeBucketName = (bucket) => {
90
+ const result = codec.encode(bucket);
91
+ if (!result.success) throw result.error;
92
+ return result.data.prefixedName;
93
+ };
94
+ const serializeBucketId = (bucket) => {
95
+ const result = codec.encode(bucket);
96
+ if (!result.success) throw result.error;
97
+ return result.data.id;
98
+ };
99
+ const serializeTableId = (table) => `${serializeBucketId(table.bucket)}.${nameSchema.parse(table.name)}`;
100
+ const safeSerializeBucketName = (bucket) => {
101
+ const result = codec.encode(bucket);
102
+ if (!result.success) return null;
103
+ return result.data.prefixedName;
104
+ };
105
+ const safeSerializeBucketId = (bucket) => {
106
+ const result = codec.encode(bucket);
107
+ if (!result.success) return null;
108
+ return result.data.id;
109
+ };
110
+ const safeSerializeTableId = (table) => {
111
+ const bucketId = safeSerializeBucketId(table.bucket);
112
+ const tableNameResult = nameSchema.safeParse(table.name);
113
+ if (!bucketId || !tableNameResult.success) return null;
114
+ return `${bucketId}.${tableNameResult.data}`;
115
+ };
116
+ const parse = (id) => {
117
+ const data = tableIdSchema.parse(id);
118
+ return decodeTable(...data);
119
+ };
120
+ const safeParse = (id) => {
121
+ const parseResult = tableIdSchema.safeParse(id);
122
+ if (!parseResult.success) return null;
123
+ return decodeTable(...parseResult.data);
124
+ };
125
+ const parseBucket = (id) => {
126
+ const [stage, bucketName] = bucketIdSchema.parse(id);
127
+ return { ...codec.decode(bucketName), stage };
128
+ };
129
+ const safeParseBucket = (id) => {
130
+ const parseResult = bucketIdSchema.safeParse(id);
131
+ if (!parseResult.success) return null;
132
+ const [stage, bucketName] = parseResult.data;
133
+ return { ...codec.decode(bucketName), stage };
134
+ };
135
+ const createBucket = (input) => {
136
+ const decoded = codec.decode(input.name);
137
+ if (decoded.kind === "storage-branch")
138
+ return { ...decoded, stage: input.stage, hasLegacyPrefix: options.useLegacyBucketPrefix };
139
+ return {
140
+ ...decoded,
141
+ stage: input.stage,
142
+ hasLegacyPrefix: options.useLegacyBucketPrefix,
143
+ branchId: input.branchId ?? decoded.branchId
144
+ };
145
+ };
146
+ const createTable = (input) => ({
147
+ name: input.tableName,
148
+ bucket: createBucket({ stage: input.stage, name: input.bucketName, branchId: input.branchId })
149
+ });
150
+ return {
151
+ parse,
152
+ safeParse,
153
+ parseBucket,
154
+ safeParseBucket,
155
+ createTable,
156
+ createBucket,
157
+ serializeTableId,
158
+ serializeBucketId,
159
+ serializeBucketName,
160
+ serializeBucketDisplayName,
161
+ safeSerializeTableId,
162
+ safeSerializeBucketId,
163
+ safeSerializeBucketName
164
+ };
165
+ };
166
+
167
+ // src/domain/storageTable/utils.ts
168
+ var webalize = (str) => {
169
+ const out = str.normalize("NFD").replace(/\p{M}/gu, "").toLowerCase().replace(/[^a-z0-9\-_]/g, "-").replace(/-+/g, "-").replace(/^-+|-+$/g, "").replace(/^_+/, "").slice(0, NAME_MAX_LENGTH).replace(/-+$/g, "");
170
+ if (out.length === 0) {
171
+ throw new Error(`Cannot webalize "${str}" into a valid name segment`);
172
+ }
173
+ return out;
174
+ };
175
+
176
+ // src/domain/storageTable/createStorageTable.ts
177
+ var createStorageTable = (flags) => {
178
+ const model = createTableModel(flags);
179
+ const branchIt = (bucket, branchId) => bucket.kind !== "legacy" ? bucket : { ...bucket, branchId };
180
+ const unbranchIt = (bucket, branchId) => bucket.kind !== "legacy" || bucket.branchId !== branchId ? bucket : { ...bucket, branchId: null };
181
+ const make = (bucket, tableName) => {
182
+ const self = {
183
+ bucket,
184
+ name: tableName,
185
+ isInBranch: (branchId) => bucket.kind === "legacy" && bucket.branchId === branchId,
186
+ addBranch: (branchId) => {
187
+ if (branchId.length === 0) throw new Error("branchId is required");
188
+ return make(branchIt(bucket, branchId), tableName);
189
+ },
190
+ removeBranch: (branchId) => {
191
+ if (branchId.length === 0) throw new Error("branchId is required");
192
+ return make(unbranchIt(bucket, branchId), tableName);
193
+ },
194
+ addTableName: (name) => {
195
+ if (name.length === 0) throw new Error("tableName is required");
196
+ return make(bucket, name);
197
+ },
198
+ getBucketName: () => model.serializeBucketName(bucket),
199
+ getBucketDisplayName: () => model.serializeBucketDisplayName(bucket),
200
+ getBucketBaseName: () => bucket.baseName,
201
+ getTableName: () => {
202
+ if (tableName === null)
203
+ throw new Error(
204
+ "getTableName() requires a table name \u2014 instance was built via createBucket"
205
+ );
206
+ return tableName;
207
+ },
208
+ getBucketId: () => model.serializeBucketId(bucket),
209
+ getTableId: () => model.serializeTableId({ bucket, name: tableName ?? "" }),
210
+ getSafeBucketId: () => model.safeSerializeBucketId(bucket),
211
+ getSafeTableId: () => model.safeSerializeTableId({ bucket, name: tableName ?? "" })
212
+ };
213
+ return self;
214
+ };
215
+ const parse = (id) => {
216
+ const table = model.parse(id);
217
+ return make(table.bucket, table.name);
218
+ };
219
+ const safeParse = (id) => {
220
+ const table = model.safeParse(id);
221
+ return table ? make(table.bucket, table.name) : null;
222
+ };
223
+ const parseBucket = (id) => make(model.parseBucket(id), null);
224
+ const safeParseBucket = (id) => {
225
+ const bucket = model.safeParseBucket(id);
226
+ return bucket ? make(bucket, null) : null;
227
+ };
228
+ const createTable = (input) => {
229
+ const { bucket, name } = model.createTable(input);
230
+ return make(bucket, name);
231
+ };
232
+ const createBucket = (input) => make(model.createBucket(input), null);
233
+ return {
234
+ // generic
235
+ parse,
236
+ safeParse,
237
+ parseBucket,
238
+ safeParseBucket,
239
+ createTable,
240
+ createBucket,
241
+ // Business
242
+ createDefaultCsvImportTable: (configId) => {
243
+ const bucketName = flags.useLegacyBucketPrefix ? "c-csv-import" : webalize(`keboola.csv-import-${configId}`);
244
+ const tableName = flags.useLegacyBucketPrefix ? configId : "data";
245
+ return createTable({
246
+ stage: "in",
247
+ tableName,
248
+ bucketName
249
+ });
250
+ },
251
+ createDefaultBucket: ({ stage, name }) => createBucket({ stage, name: webalize(name) }),
252
+ safeCreateDefaultBucket: ({ stage, name }) => {
253
+ try {
254
+ return createBucket({ stage, name: webalize(name) });
255
+ } catch {
256
+ return null;
257
+ }
258
+ },
259
+ createDefaultConfigBucket: ({ stage, componentId, configId }) => createBucket({ stage, name: webalize(`${componentId}-${configId}`) }),
260
+ createDefaultConfigTable: ({ stage, componentId, configId, tableName }) => createTable({ stage, bucketName: webalize(`${componentId}-${configId}`), tableName })
261
+ };
262
+ };
263
+
264
+ exports.createStorageTable = createStorageTable;
265
+ exports.createTableModel = createTableModel;
266
+ //# sourceMappingURL=index.cjs.map
267
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/domain/storageTable/constants.ts","../../../src/domain/storageTable/schema.ts","../../../src/domain/storageTable/codec.ts","../../../src/domain/storageTable/model.ts","../../../src/domain/storageTable/utils.ts","../../../src/domain/storageTable/createStorageTable.ts"],"names":["z","prefixedName"],"mappings":";;;;;AACO,IAAM,mBAAA,GAAsB,cAAA;AAE5B,IAAM,oBAAA,GAAuB,IAAA;AAE7B,IAAM,kBAAA,GAAqB,kBAAA;AAE3B,IAAM,eAAA,GAAkB,EAAA;ACHxB,IAAM,cAAcA,KAAA,CAAE,IAAA,CAAK,CAAC,IAAA,EAAM,KAAK,CAAC,CAAA;AAExC,IAAM,UAAA,GAAaA,KAAA,CACvB,MAAA,EAAO,CACP,GAAA,CAAI,CAAA,EAAG,CAAA,uCAAA,CAAyC,CAAA,CAChD,GAAA,CAAI,eAAA,EAAiB,CAAA,8BAAA,EAAiC,eAAe,CAAA,WAAA,CAAa,EAClF,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,CAAA,CAAE,UAAA,CAAW,GAAG,CAAA,EAAG,CAAA,uDAAA,CAAyD,CAAA,CAC3F,KAAA,CAAM,kBAAA,EAAoB,CAAA,iDAAA,CAAmD,CAAA;AAEzE,IAAM,aAAA,GAAgBA,KAAA,CAC1B,MAAA,EAAO,CACP,MAAA;AAAA,EACC,CAAC,EAAA,KAAO,EAAA,CAAG,KAAA,CAAM,GAAG,EAAE,MAAA,KAAW,CAAA;AAAA,EACjC;AACF,CAAA,CACC,UAAU,CAAC,EAAA,KAAO,EAAA,CAAG,KAAA,CAAM,GAAG,CAA6B,CAAA,CAC3D,IAAA,CAAKA,KAAA,CAAE,MAAM,CAAC,WAAA,EAAa,UAAA,EAAY,UAAU,CAAC,CAAC,CAAA;AAE/C,IAAM,cAAA,GAAiBA,KAAA,CAC3B,MAAA,EAAO,CACP,MAAA;AAAA,EACC,CAAC,EAAA,KAAO,EAAA,CAAG,KAAA,CAAM,GAAG,EAAE,MAAA,KAAW,CAAA;AAAA,EACjC;AACF,CAAA,CACC,SAAA,CAAU,CAAC,EAAA,KAAO,EAAA,CAAG,MAAM,GAAG,CAAqB,CAAA,CACnD,IAAA,CAAKA,MAAE,KAAA,CAAM,CAAC,WAAA,EAAa,UAAU,CAAC,CAAC,CAAA;;;ACCnC,IAAM,oBAAoB,CAAC;AAAA,EAChC,qBAAA;AAAA,EACA,yBAAA;AAAA,EACA;AACF,CAAA,KAAoB;AAClB,EAAA,MAAM,MAAA,GAAS,CAAC,IAAA,KAAmC;AACjD,IAAA,MAAM,eAAA,GAAkB,qBAAA,IAAyB,IAAA,CAAK,UAAA,CAAW,oBAAoB,CAAA;AACrF,IAAA,MAAM,WAAW,eAAA,GAAkB,IAAA,CAAK,KAAA,CAAM,oBAAA,CAAqB,MAAM,CAAA,GAAI,IAAA;AAI7E,IAAA,IAAI,yBAAA,IAA6B,kBAAA;AAC/B,MAAA,OAAO;AAAA,QACL,IAAA,EAAM,gBAAA;AAAA,QACN,QAAA,EAAU,QAAA;AAAA,QACV;AAAA,OACF;AAEF,IAAA,MAAM,WAAA,GAAc,mBAAA,CAAoB,IAAA,CAAK,QAAQ,CAAA;AAErD,IAAA,OAAO;AAAA,MACL,IAAA,EAAM,QAAA;AAAA,MACN,eAAA;AAAA,MACA,QAAA,EAAU,WAAA,GAAc,CAAC,CAAA,IAAK,IAAA;AAAA,MAC9B,QAAA,EAAU,WAAA,GAAc,CAAC,CAAA,IAAK;AAAA,KAChC;AAAA,EACF,CAAA;AAEA,EAAA,MAAM,MAAA,GAAS,CACb,MAAA,KAC2F;AAC3F,IAAA,MAAM,WAAA,GAAc,WAAA,CAAY,SAAA,CAAU,MAAA,CAAO,KAAK,CAAA;AACtD,IAAA,IAAI,CAAC,YAAY,OAAA,EAAS,OAAO,EAAE,OAAA,EAAS,KAAA,EAAO,KAAA,EAAO,WAAA,CAAY,KAAA,EAAM;AAE5E,IAAA,MAAM,MAAA,GAAS,MAAA,CAAO,eAAA,GAAkB,oBAAA,GAAuB,EAAA;AAC/D,IAAA,MAAM,cAAA,GAAiB,UAAA,CAAW,SAAA,CAAU,MAAA,CAAO,QAAQ,CAAA;AAC3D,IAAA,IAAI,CAAC,eAAe,OAAA,EAAS,OAAO,EAAE,OAAA,EAAS,KAAA,EAAO,KAAA,EAAO,cAAA,CAAe,KAAA,EAAM;AAElF,IAAA,IAAI,MAAA,CAAO,SAAS,gBAAA,EAAkB;AACpC,MAAA,MAAMC,aAAAA,GAAe,CAAA,EAAG,MAAM,CAAA,EAAG,OAAO,QAAQ,CAAA,CAAA;AAEhD,MAAA,OAAO;AAAA,QACL,OAAA,EAAS,IAAA;AAAA,QACT,IAAA,EAAM;AAAA,UACJ,IAAA,EAAM,gBAAA;AAAA,UACN,EAAA,EAAI,CAAA,EAAG,MAAA,CAAO,KAAK,IAAIA,aAAY,CAAA,CAAA;AAAA,UACnC,YAAA,EAAAA;AAAA;AACF,OACF;AAAA,IACF;AAEA,IAAA,MAAM,SAAS,MAAA,CAAO,QAAA,GAAW,CAAA,EAAG,MAAA,CAAO,QAAQ,CAAA,CAAA,CAAA,GAAM,EAAA;AACzD,IAAA,MAAM,YAAA,GAAe,CAAA,EAAG,MAAM,CAAA,EAAG,OAAO,QAAQ,CAAA,CAAA;AAChD,IAAA,MAAM,YAAA,GAAe,CAAA,EAAG,MAAM,CAAA,EAAG,YAAY,CAAA,CAAA;AAE7C,IAAA,OAAO;AAAA,MACL,OAAA,EAAS,IAAA;AAAA,MACT,IAAA,EAAM;AAAA,QACJ,IAAA,EAAM,QAAA;AAAA,QACN,EAAA,EAAI,CAAA,EAAG,MAAA,CAAO,KAAK,IAAI,YAAY,CAAA,CAAA;AAAA,QACnC,YAAA;AAAA,QACA;AAAA;AACF,KACF;AAAA,EACF,CAAA;AAEA,EAAA,OAAO,EAAE,QAAQ,MAAA,EAAO;AAC1B,CAAA;;;ACnDO,IAAM,gBAAA,GAAmB,CAAC,OAAA,KAAsC;AACrE,EAAA,MAAM,KAAA,GAAQ,kBAAkB,OAAO,CAAA;AAEvC,EAAA,MAAM,WAAA,GAAc,CAAC,KAAA,EAAoB,UAAA,EAAoB,SAAA,MAA8B;AAAA,IACzF,IAAA,EAAM,SAAA;AAAA,IACN,QAAQ,EAAE,GAAG,MAAM,MAAA,CAAO,UAAU,GAAG,KAAA;AAAM,GAC/C,CAAA;AAEA,EAAA,MAAM,0BAAA,GAA6B,CAAC,MAAA,KAAmB;AACrD,IAAA,MAAM,MAAA,GAAS,KAAA,CAAM,MAAA,CAAO,MAAM,CAAA;AAClC,IAAA,IAAI,CAAC,MAAA,CAAO,OAAA,EAAS,MAAM,MAAA,CAAO,KAAA;AAGlC,IAAA,OAAO,OAAO,IAAA,CAAK,IAAA,KAAS,mBAAmB,MAAA,CAAO,QAAA,GAAW,OAAO,IAAA,CAAK,YAAA;AAAA,EAC/E,CAAA;AAEA,EAAA,MAAM,mBAAA,GAAsB,CAAC,MAAA,KAAmB;AAC9C,IAAA,MAAM,MAAA,GAAS,KAAA,CAAM,MAAA,CAAO,MAAM,CAAA;AAClC,IAAA,IAAI,CAAC,MAAA,CAAO,OAAA,EAAS,MAAM,MAAA,CAAO,KAAA;AAClC,IAAA,OAAO,OAAO,IAAA,CAAK,YAAA;AAAA,EACrB,CAAA;AAEA,EAAA,MAAM,iBAAA,GAAoB,CAAC,MAAA,KAA6B;AACtD,IAAA,MAAM,MAAA,GAAS,KAAA,CAAM,MAAA,CAAO,MAAM,CAAA;AAClC,IAAA,IAAI,CAAC,MAAA,CAAO,OAAA,EAAS,MAAM,MAAA,CAAO,KAAA;AAClC,IAAA,OAAO,OAAO,IAAA,CAAK,EAAA;AAAA,EACrB,CAAA;AAEA,EAAA,MAAM,gBAAA,GAAmB,CAAC,KAAA,KACxB,CAAA,EAAG,iBAAA,CAAkB,KAAA,CAAM,MAAM,CAAC,CAAA,CAAA,EAAI,UAAA,CAAW,KAAA,CAAM,KAAA,CAAM,IAAI,CAAC,CAAA,CAAA;AAGpE,EAAA,MAAM,uBAAA,GAA0B,CAAC,MAAA,KAAsC;AACrE,IAAA,MAAM,MAAA,GAAS,KAAA,CAAM,MAAA,CAAO,MAAM,CAAA;AAClC,IAAA,IAAI,CAAC,MAAA,CAAO,OAAA,EAAS,OAAO,IAAA;AAC5B,IAAA,OAAO,OAAO,IAAA,CAAK,YAAA;AAAA,EACrB,CAAA;AAEA,EAAA,MAAM,qBAAA,GAAwB,CAAC,MAAA,KAAoC;AACjE,IAAA,MAAM,MAAA,GAAS,KAAA,CAAM,MAAA,CAAO,MAAM,CAAA;AAClC,IAAA,IAAI,CAAC,MAAA,CAAO,OAAA,EAAS,OAAO,IAAA;AAC5B,IAAA,OAAO,OAAO,IAAA,CAAK,EAAA;AAAA,EACrB,CAAA;AAEA,EAAA,MAAM,oBAAA,GAAuB,CAAC,KAAA,KAAiC;AAC7D,IAAA,MAAM,QAAA,GAAW,qBAAA,CAAsB,KAAA,CAAM,MAAM,CAAA;AACnD,IAAA,MAAM,eAAA,GAAkB,UAAA,CAAW,SAAA,CAAU,KAAA,CAAM,IAAI,CAAA;AACvD,IAAA,IAAI,CAAC,QAAA,IAAY,CAAC,eAAA,CAAgB,SAAS,OAAO,IAAA;AAClD,IAAA,OAAO,CAAA,EAAG,QAAQ,CAAA,CAAA,EAAI,eAAA,CAAgB,IAAI,CAAA,CAAA;AAAA,EAC5C,CAAA;AAEA,EAAA,MAAM,KAAA,GAAQ,CAAC,EAAA,KAAe;AAC5B,IAAA,MAAM,IAAA,GAAO,aAAA,CAAc,KAAA,CAAM,EAAE,CAAA;AACnC,IAAA,OAAO,WAAA,CAAY,GAAG,IAAI,CAAA;AAAA,EAC5B,CAAA;AAEA,EAAA,MAAM,SAAA,GAAY,CAAC,EAAA,KAA6B;AAC9C,IAAA,MAAM,WAAA,GAAc,aAAA,CAAc,SAAA,CAAU,EAAE,CAAA;AAC9C,IAAA,IAAI,CAAC,WAAA,CAAY,OAAA,EAAS,OAAO,IAAA;AACjC,IAAA,OAAO,WAAA,CAAY,GAAG,WAAA,CAAY,IAAI,CAAA;AAAA,EACxC,CAAA;AAEA,EAAA,MAAM,WAAA,GAAc,CAAC,EAAA,KAAuB;AAC1C,IAAA,MAAM,CAAC,KAAA,EAAO,UAAU,CAAA,GAAI,cAAA,CAAe,MAAM,EAAE,CAAA;AACnD,IAAA,OAAO,EAAE,GAAG,KAAA,CAAM,MAAA,CAAO,UAAU,GAAG,KAAA,EAAM;AAAA,EAC9C,CAAA;AAEA,EAAA,MAAM,eAAA,GAAkB,CAAC,EAAA,KAA8B;AACrD,IAAA,MAAM,WAAA,GAAc,cAAA,CAAe,SAAA,CAAU,EAAE,CAAA;AAC/C,IAAA,IAAI,CAAC,WAAA,CAAY,OAAA,EAAS,OAAO,IAAA;AACjC,IAAA,MAAM,CAAC,KAAA,EAAO,UAAU,CAAA,GAAI,WAAA,CAAY,IAAA;AACxC,IAAA,OAAO,EAAE,GAAG,KAAA,CAAM,MAAA,CAAO,UAAU,GAAG,KAAA,EAAM;AAAA,EAC9C,CAAA;AAEA,EAAA,MAAM,YAAA,GAA+B,CAAC,KAAA,KAAU;AAG9C,IAAA,MAAM,OAAA,GAAU,KAAA,CAAM,MAAA,CAAO,KAAA,CAAM,IAAI,CAAA;AAGvC,IAAA,IAAI,QAAQ,IAAA,KAAS,gBAAA;AACnB,MAAA,OAAO,EAAE,GAAG,OAAA,EAAS,KAAA,EAAO,MAAM,KAAA,EAAO,eAAA,EAAiB,QAAQ,qBAAA,EAAsB;AAE1F,IAAA,OAAO;AAAA,MACL,GAAG,OAAA;AAAA,MACH,OAAO,KAAA,CAAM,KAAA;AAAA,MACb,iBAAiB,OAAA,CAAQ,qBAAA;AAAA,MACzB,QAAA,EAAU,KAAA,CAAM,QAAA,IAAY,OAAA,CAAQ;AAAA,KACtC;AAAA,EACF,CAAA;AAEA,EAAA,MAAM,WAAA,GAA6B,CAAC,KAAA,MAAW;AAAA,IAC7C,MAAM,KAAA,CAAM,SAAA;AAAA,IACZ,MAAA,EAAQ,YAAA,CAAa,EAAE,KAAA,EAAO,KAAA,CAAM,KAAA,EAAO,IAAA,EAAM,KAAA,CAAM,UAAA,EAAY,QAAA,EAAU,KAAA,CAAM,QAAA,EAAU;AAAA,GAC/F,CAAA;AAEA,EAAA,OAAO;AAAA,IACL,KAAA;AAAA,IACA,SAAA;AAAA,IACA,WAAA;AAAA,IACA,eAAA;AAAA,IAEA,WAAA;AAAA,IACA,YAAA;AAAA,IAEA,gBAAA;AAAA,IACA,iBAAA;AAAA,IACA,mBAAA;AAAA,IACA,0BAAA;AAAA,IAEA,oBAAA;AAAA,IACA,qBAAA;AAAA,IACA;AAAA,GACF;AACF;;;AC9JO,IAAM,QAAA,GAAW,CAAC,GAAA,KAAwB;AAC/C,EAAA,MAAM,GAAA,GAAM,GAAA,CACT,SAAA,CAAU,KAAK,EACf,OAAA,CAAQ,SAAA,EAAW,EAAE,CAAA,CACrB,WAAA,EAAY,CACZ,OAAA,CAAQ,eAAA,EAAiB,GAAG,CAAA,CAC5B,OAAA,CAAQ,KAAA,EAAO,GAAG,CAAA,CAClB,OAAA,CAAQ,UAAA,EAAY,EAAE,EACtB,OAAA,CAAQ,KAAA,EAAO,EAAE,CAAA,CACjB,MAAM,CAAA,EAAG,eAAe,CAAA,CACxB,OAAA,CAAQ,QAAQ,EAAE,CAAA;AAErB,EAAA,IAAI,GAAA,CAAI,WAAW,CAAA,EAAG;AACpB,IAAA,MAAM,IAAI,KAAA,CAAM,CAAA,iBAAA,EAAoB,GAAG,CAAA,2BAAA,CAA6B,CAAA;AAAA,EACtE;AAEA,EAAA,OAAO,GAAA;AACT,CAAA;;;AC2CO,IAAM,kBAAA,GAAqB,CAAC,KAAA,KAAsC;AACvE,EAAA,MAAM,KAAA,GAAQ,iBAAiB,KAAK,CAAA;AAEpC,EAAA,MAAM,QAAA,GAAW,CAAC,MAAA,EAAgB,QAAA,KAChC,MAAA,CAAO,IAAA,KAAS,QAAA,GAAW,MAAA,GAAS,EAAE,GAAG,MAAA,EAAQ,QAAA,EAAS;AAE5D,EAAA,MAAM,UAAA,GAAa,CAAC,MAAA,EAAgB,QAAA,KAClC,OAAO,IAAA,KAAS,QAAA,IAAY,MAAA,CAAO,QAAA,KAAa,WAC5C,MAAA,GACA,EAAE,GAAG,MAAA,EAAQ,UAAU,IAAA,EAAK;AAElC,EAAA,MAAM,IAAA,GAAO,CAAC,MAAA,EAAgB,SAAA,KAAsD;AAClF,IAAA,MAAM,IAAA,GAA6B;AAAA,MACjC,MAAA;AAAA,MACA,IAAA,EAAM,SAAA;AAAA,MACN,YAAY,CAAC,QAAA,KAAa,OAAO,IAAA,KAAS,QAAA,IAAY,OAAO,QAAA,KAAa,QAAA;AAAA,MAC1E,SAAA,EAAW,CAAC,QAAA,KAAa;AACvB,QAAA,IAAI,SAAS,MAAA,KAAW,CAAA,EAAG,MAAM,IAAI,MAAM,sBAAsB,CAAA;AACjE,QAAA,OAAO,IAAA,CAAK,QAAA,CAAS,MAAA,EAAQ,QAAQ,GAAG,SAAS,CAAA;AAAA,MACnD,CAAA;AAAA,MACA,YAAA,EAAc,CAAC,QAAA,KAAa;AAC1B,QAAA,IAAI,SAAS,MAAA,KAAW,CAAA,EAAG,MAAM,IAAI,MAAM,sBAAsB,CAAA;AACjE,QAAA,OAAO,IAAA,CAAK,UAAA,CAAW,MAAA,EAAQ,QAAQ,GAAG,SAAS,CAAA;AAAA,MACrD,CAAA;AAAA,MACA,YAAA,EAAc,CAAC,IAAA,KAAS;AACtB,QAAA,IAAI,KAAK,MAAA,KAAW,CAAA,EAAG,MAAM,IAAI,MAAM,uBAAuB,CAAA;AAC9D,QAAA,OAAO,IAAA,CAAK,QAAQ,IAAI,CAAA;AAAA,MAC1B,CAAA;AAAA,MAEA,aAAA,EAAe,MAAM,KAAA,CAAM,mBAAA,CAAoB,MAAM,CAAA;AAAA,MACrD,oBAAA,EAAsB,MAAM,KAAA,CAAM,0BAAA,CAA2B,MAAM,CAAA;AAAA,MACnE,iBAAA,EAAmB,MAAM,MAAA,CAAO,QAAA;AAAA,MAChC,cAAc,MAAM;AAClB,QAAA,IAAI,SAAA,KAAc,IAAA;AAChB,UAAA,MAAM,IAAI,KAAA;AAAA,YACR;AAAA,WACF;AACF,QAAA,OAAO,SAAA;AAAA,MACT,CAAA;AAAA,MAEA,WAAA,EAAa,MAAM,KAAA,CAAM,iBAAA,CAAkB,MAAM,CAAA;AAAA,MACjD,UAAA,EAAY,MAAM,KAAA,CAAM,gBAAA,CAAiB,EAAE,MAAA,EAAQ,IAAA,EAAM,SAAA,IAAa,EAAA,EAAI,CAAA;AAAA,MAE1E,eAAA,EAAiB,MAAM,KAAA,CAAM,qBAAA,CAAsB,MAAM,CAAA;AAAA,MACzD,cAAA,EAAgB,MAAM,KAAA,CAAM,oBAAA,CAAqB,EAAE,MAAA,EAAQ,IAAA,EAAM,SAAA,IAAa,EAAA,EAAI;AAAA,KACpF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT,CAAA;AAEA,EAAA,MAAM,KAAA,GAAQ,CAAC,EAAA,KAAgB;AAC7B,IAAA,MAAM,KAAA,GAAQ,KAAA,CAAM,KAAA,CAAM,EAAE,CAAA;AAC5B,IAAA,OAAO,IAAA,CAAK,KAAA,CAAM,MAAA,EAAQ,KAAA,CAAM,IAAI,CAAA;AAAA,EACtC,CAAA;AACA,EAAA,MAAM,SAAA,GAAY,CAAC,EAAA,KAAgB;AACjC,IAAA,MAAM,KAAA,GAAQ,KAAA,CAAM,SAAA,CAAU,EAAE,CAAA;AAChC,IAAA,OAAO,QAAQ,IAAA,CAAK,KAAA,CAAM,MAAA,EAAQ,KAAA,CAAM,IAAI,CAAA,GAAI,IAAA;AAAA,EAClD,CAAA;AAEA,EAAA,MAAM,WAAA,GAAc,CAAC,EAAA,KAAiB,IAAA,CAAK,MAAM,WAAA,CAAY,EAAE,GAAG,IAAI,CAAA;AAEtE,EAAA,MAAM,eAAA,GAAkB,CAAC,EAAA,KAAiB;AACxC,IAAA,MAAM,MAAA,GAAS,KAAA,CAAM,eAAA,CAAgB,EAAE,CAAA;AACvC,IAAA,OAAO,MAAA,GAAS,IAAA,CAAK,MAAA,EAAQ,IAAI,CAAA,GAAI,IAAA;AAAA,EACvC,CAAA;AAEA,EAAA,MAAM,WAAA,GAAc,CAAC,KAAA,KAAwC;AAC3D,IAAA,MAAM,EAAE,MAAA,EAAQ,IAAA,EAAK,GAAI,KAAA,CAAM,YAAY,KAAK,CAAA;AAChD,IAAA,OAAO,IAAA,CAAK,QAAQ,IAAI,CAAA;AAAA,EAC1B,CAAA;AAEA,EAAA,MAAM,YAAA,GAAe,CAAC,KAAA,KACpB,IAAA,CAAK,MAAM,YAAA,CAAa,KAAK,GAAG,IAAI,CAAA;AAEtC,EAAA,OAAO;AAAA;AAAA,IAEL,KAAA;AAAA,IACA,SAAA;AAAA,IACA,WAAA;AAAA,IACA,eAAA;AAAA,IACA,WAAA;AAAA,IACA,YAAA;AAAA;AAAA,IAGA,2BAAA,EAA6B,CAAC,QAAA,KAAqB;AACjD,MAAA,MAAM,aAAa,KAAA,CAAM,qBAAA,GACrB,iBACA,QAAA,CAAS,CAAA,mBAAA,EAAsB,QAAQ,CAAA,CAAE,CAAA;AAC7C,MAAA,MAAM,SAAA,GAAY,KAAA,CAAM,qBAAA,GAAwB,QAAA,GAAW,MAAA;AAE3D,MAAA,OAAO,WAAA,CAAY;AAAA,QACjB,KAAA,EAAO,IAAA;AAAA,QACP,SAAA;AAAA,QACA;AAAA,OACD,CAAA;AAAA,IACH,CAAA;AAAA,IACA,mBAAA,EAAqB,CAAC,EAAE,KAAA,EAAO,IAAA,EAAK,KAAM,YAAA,CAAa,EAAE,KAAA,EAAO,IAAA,EAAM,QAAA,CAAS,IAAI,GAAG,CAAA;AAAA,IACtF,uBAAA,EAAyB,CAAC,EAAE,KAAA,EAAO,MAAK,KAAM;AAC5C,MAAA,IAAI;AACF,QAAA,OAAO,aAAa,EAAE,KAAA,EAAO,MAAM,QAAA,CAAS,IAAI,GAAG,CAAA;AAAA,MACrD,CAAA,CAAA,MAAQ;AAEN,QAAA,OAAO,IAAA;AAAA,MACT;AAAA,IACF,CAAA;AAAA,IACA,2BAA2B,CAAC,EAAE,OAAO,WAAA,EAAa,QAAA,OAChD,YAAA,CAAa,EAAE,KAAA,EAAO,IAAA,EAAM,SAAS,CAAA,EAAG,WAAW,IAAI,QAAQ,CAAA,CAAE,GAAG,CAAA;AAAA,IACtE,wBAAA,EAA0B,CAAC,EAAE,KAAA,EAAO,aAAa,QAAA,EAAU,SAAA,OACzD,WAAA,CAAY,EAAE,OAAO,UAAA,EAAY,QAAA,CAAS,GAAG,WAAW,CAAA,CAAA,EAAI,QAAQ,CAAA,CAAE,CAAA,EAAG,WAAW;AAAA,GACxF;AACF","file":"index.cjs","sourcesContent":["/** Matches a numeric dev-branch prefix on a legacy-prefix-stripped bucket name. */\nexport const BRANCH_PREFIX_REGEX = /^(\\d+)-(.+)$/;\n/** Historical `c-` prefix Storage prepends to legacy bucket names. */\nexport const LEGACY_BUCKET_PREFIX = 'c-';\n/** Characters allowed in a bucket or table name segment. */\nexport const NAME_CHARSET_REGEX = /^[a-zA-Z0-9_-]+$/;\n/** Max length of a bucket or table name segment. */\nexport const NAME_MAX_LENGTH = 96;\n","import { z } from 'zod';\n\nimport { NAME_CHARSET_REGEX, NAME_MAX_LENGTH } from './constants';\n\nexport const stageSchema = z.enum(['in', 'out']);\n\nexport const nameSchema = z\n .string()\n .min(1, `Invalid name segment: must not be empty`)\n .max(NAME_MAX_LENGTH, `Invalid name segment: exceeds ${NAME_MAX_LENGTH} characters`)\n .refine((n) => !n.startsWith('_'), `Invalid name segment: must not start with an underscore`)\n .regex(NAME_CHARSET_REGEX, `Invalid name segment: contains invalid characters`);\n\nexport const tableIdSchema = z\n .string()\n .refine(\n (id) => id.split('.').length === 3,\n 'Invalid table id: must be in \"{stage}.{bucket}.{table}\" form',\n )\n .transform((id) => id.split('.') as [string, string, string])\n .pipe(z.tuple([stageSchema, nameSchema, nameSchema]));\n\nexport const bucketIdSchema = z\n .string()\n .refine(\n (id) => id.split('.').length === 2,\n 'Invalid bucket id: must be in \"{stage}.{bucket}\" form',\n )\n .transform((id) => id.split('.') as [string, string])\n .pipe(z.tuple([stageSchema, nameSchema]));\n","import type z from 'zod';\n\nimport { BRANCH_PREFIX_REGEX, LEGACY_BUCKET_PREFIX } from './constants';\nimport { nameSchema, stageSchema } from './schema';\nimport type {\n Bucket,\n BucketId,\n BucketName,\n LegacyBucket,\n ModelOptions,\n ParsedBucket,\n StorageBranchBucket,\n} from './types';\n\ntype EncodedBucket =\n | {\n kind: 'legacy';\n id: BucketId;\n /** baseName + `{branchId}-` prefix, without `c-`. User-facing. e.g. `123-main` */\n branchedName: BucketName;\n /** baseName + branch + `c-` prefix. On-disk (Storage `bucket.name`). e.g. `c-123-main` */\n prefixedName: BucketName;\n }\n | {\n kind: 'storage-branch';\n id: BucketId;\n /** baseName + `c-` prefix when hasLegacyPrefix. On-disk (Storage `bucket.name`). e.g. `c-main` */\n prefixedName: BucketName;\n };\n\nexport const createBucketCodec = ({\n useLegacyBucketPrefix,\n hasProtectedDefaultBranch,\n hasStorageBranches,\n}: ModelOptions) => {\n const decode = (name: BucketName): ParsedBucket => {\n const hasLegacyPrefix = useLegacyBucketPrefix && name.startsWith(LEGACY_BUCKET_PREFIX);\n const stripped = hasLegacyPrefix ? name.slice(LEGACY_BUCKET_PREFIX.length) : name;\n\n // Native branched storage: branch is BE-side (no `{branchId}-` decoration), but the\n // legacy `c-` prefix is still applied independently of the branch model.\n if (hasProtectedDefaultBranch || hasStorageBranches)\n return {\n kind: 'storage-branch',\n baseName: stripped,\n hasLegacyPrefix,\n } satisfies StorageBranchBucket;\n\n const branchMatch = BRANCH_PREFIX_REGEX.exec(stripped);\n\n return {\n kind: 'legacy',\n hasLegacyPrefix,\n branchId: branchMatch?.[1] ?? null,\n baseName: branchMatch?.[2] ?? stripped,\n } satisfies LegacyBucket;\n };\n\n const encode = (\n bucket: Bucket,\n ): { success: true; data: EncodedBucket } | { success: false; error: z.ZodError<string> } => {\n const stageResult = stageSchema.safeParse(bucket.stage);\n if (!stageResult.success) return { success: false, error: stageResult.error };\n\n const prefix = bucket.hasLegacyPrefix ? LEGACY_BUCKET_PREFIX : '';\n const baseNameResult = nameSchema.safeParse(bucket.baseName);\n if (!baseNameResult.success) return { success: false, error: baseNameResult.error };\n\n if (bucket.kind === 'storage-branch') {\n const prefixedName = `${prefix}${bucket.baseName}`;\n\n return {\n success: true,\n data: {\n kind: 'storage-branch',\n id: `${bucket.stage}.${prefixedName}` satisfies BucketId,\n prefixedName,\n },\n };\n }\n\n const branch = bucket.branchId ? `${bucket.branchId}-` : '';\n const branchedName = `${branch}${bucket.baseName}`;\n const prefixedName = `${prefix}${branchedName}`;\n\n return {\n success: true,\n data: {\n kind: 'legacy',\n id: `${bucket.stage}.${prefixedName}` satisfies BucketId,\n prefixedName,\n branchedName,\n },\n };\n };\n\n return { decode, encode };\n};\n","import { createBucketCodec } from './codec';\nimport { bucketIdSchema, nameSchema, tableIdSchema } from './schema';\nimport type {\n Bucket,\n BucketId,\n BucketName,\n BucketStage,\n ModelOptions,\n Table,\n TableId,\n TableName,\n} from './types';\n\nexport type CreateBucketFn = (input: {\n stage: BucketStage;\n name: BucketName;\n branchId?: string | null;\n}) => Bucket;\n\nexport type CreateTableFn = (input: {\n stage: BucketStage;\n tableName: TableName;\n bucketName: BucketName;\n branchId?: string | null;\n}) => Table;\n\nexport type TableModel = {\n parse(id: string): Table;\n parseBucket(id: string): Bucket;\n\n safeParse(id: string): Table | null;\n safeParseBucket(id: string): Bucket | null;\n\n serializeTableId(table: Table): TableId;\n serializeBucketId(bucket: Bucket): BucketId;\n serializeBucketName(bucket: Bucket): BucketName;\n serializeBucketDisplayName(bucket: Bucket): BucketName;\n\n safeSerializeTableId(table: Table): TableId | null;\n safeSerializeBucketId(bucket: Bucket): BucketId | null;\n safeSerializeBucketName(bucket: Bucket): BucketName | null;\n\n createTable: CreateTableFn;\n createBucket: CreateBucketFn;\n};\n\nexport const createTableModel = (options: ModelOptions): TableModel => {\n const codec = createBucketCodec(options);\n\n const decodeTable = (stage: BucketStage, bucketName: string, tableName: string): Table => ({\n name: tableName,\n bucket: { ...codec.decode(bucketName), stage },\n });\n\n const serializeBucketDisplayName = (bucket: Bucket) => {\n const result = codec.encode(bucket);\n if (!result.success) throw result.error;\n // Storage-branch display name is just the bare baseName (no branch decoration to apply);\n // encode is still called so the empty-name guard throws consistently.\n return result.data.kind === 'storage-branch' ? bucket.baseName : result.data.branchedName;\n };\n\n const serializeBucketName = (bucket: Bucket) => {\n const result = codec.encode(bucket);\n if (!result.success) throw result.error;\n return result.data.prefixedName;\n };\n\n const serializeBucketId = (bucket: Bucket): BucketId => {\n const result = codec.encode(bucket);\n if (!result.success) throw result.error;\n return result.data.id;\n };\n\n const serializeTableId = (table: Table): TableId =>\n `${serializeBucketId(table.bucket)}.${nameSchema.parse(table.name)}`;\n\n // Safe counterparts: return null instead of throwing when a required segment is empty.\n const safeSerializeBucketName = (bucket: Bucket): BucketName | null => {\n const result = codec.encode(bucket);\n if (!result.success) return null;\n return result.data.prefixedName;\n };\n\n const safeSerializeBucketId = (bucket: Bucket): BucketId | null => {\n const result = codec.encode(bucket);\n if (!result.success) return null;\n return result.data.id;\n };\n\n const safeSerializeTableId = (table: Table): TableId | null => {\n const bucketId = safeSerializeBucketId(table.bucket);\n const tableNameResult = nameSchema.safeParse(table.name);\n if (!bucketId || !tableNameResult.success) return null;\n return `${bucketId}.${tableNameResult.data}`;\n };\n\n const parse = (id: string) => {\n const data = tableIdSchema.parse(id);\n return decodeTable(...data);\n };\n\n const safeParse = (id: string): Table | null => {\n const parseResult = tableIdSchema.safeParse(id);\n if (!parseResult.success) return null;\n return decodeTable(...parseResult.data);\n };\n\n const parseBucket = (id: string): Bucket => {\n const [stage, bucketName] = bucketIdSchema.parse(id);\n return { ...codec.decode(bucketName), stage };\n };\n\n const safeParseBucket = (id: string): Bucket | null => {\n const parseResult = bucketIdSchema.safeParse(id);\n if (!parseResult.success) return null;\n const [stage, bucketName] = parseResult.data;\n return { ...codec.decode(bucketName), stage };\n };\n\n const createBucket: CreateBucketFn = (input) => {\n // Normalize the input the same way decoding does (strips a `c-`/`{branchId}-`\n // a caller may have passed), so `baseName` always holds the bare name.\n const decoded = codec.decode(input.name);\n // On create the prefix is decided by the project flag — not by whether the\n // input happened to start with `c-`. This applies to both bucket models.\n if (decoded.kind === 'storage-branch')\n return { ...decoded, stage: input.stage, hasLegacyPrefix: options.useLegacyBucketPrefix };\n\n return {\n ...decoded,\n stage: input.stage,\n hasLegacyPrefix: options.useLegacyBucketPrefix,\n branchId: input.branchId ?? decoded.branchId,\n };\n };\n\n const createTable: CreateTableFn = (input) => ({\n name: input.tableName,\n bucket: createBucket({ stage: input.stage, name: input.bucketName, branchId: input.branchId }),\n });\n\n return {\n parse,\n safeParse,\n parseBucket,\n safeParseBucket,\n\n createTable,\n createBucket,\n\n serializeTableId,\n serializeBucketId,\n serializeBucketName,\n serializeBucketDisplayName,\n\n safeSerializeTableId,\n safeSerializeBucketId,\n safeSerializeBucketName,\n };\n};\n","import { NAME_MAX_LENGTH } from './constants';\n\nexport const webalize = (str: string): string => {\n const out = str\n .normalize('NFD')\n .replace(/\\p{M}/gu, '') // strip diacritics after NFD decomposition: á→a, č→c, ý→y …\n .toLowerCase()\n .replace(/[^a-z0-9\\-_]/g, '-')\n .replace(/-+/g, '-')\n .replace(/^-+|-+$/g, '')\n .replace(/^_+/, '')\n .slice(0, NAME_MAX_LENGTH)\n .replace(/-+$/g, '');\n\n if (out.length === 0) {\n throw new Error(`Cannot webalize \"${str}\" into a valid name segment`);\n }\n\n return out;\n};\n","import { type CreateBucketFn, type CreateTableFn, createTableModel } from './model';\nimport type {\n Bucket,\n BucketId,\n BucketName,\n BucketStage,\n ModelOptions,\n TableId,\n TableName,\n} from './types';\nimport { webalize } from './utils';\n\nexport type StorageTableInstance = {\n readonly bucket: Bucket;\n readonly name: TableName | null;\n isInBranch(branchId: string): boolean;\n addBranch(branchId: string): StorageTableInstance;\n removeBranch(branchId: string): StorageTableInstance;\n /** A new instance with the table name set (or replaced). */\n addTableName(tableName: TableName): StorageTableInstance;\n getBucketName(): BucketName;\n /** Bucket name as shown to users: dev-branch prefix kept, legacy `c-` prefix always dropped. */\n getBucketDisplayName(): BucketName;\n /** Bare bucket name: no `c-` prefix, no dev-branch prefix (legacy `baseName`, or the canonical storage-branch name). */\n getBucketBaseName(): BucketName;\n getBucketId(): BucketId;\n getSafeBucketId(): BucketId | null;\n /** @throws when there is no table name (the instance was built via `createBucket`). */\n getTableName(): TableName;\n /** @throws when there is no table name (the instance was built via `createBucket`). */\n getTableId(): TableId;\n /** Null when there is no table name (built via `createBucket`) or a segment is empty. */\n getSafeTableId(): TableId | null;\n};\n\nexport type StorageTable = {\n parse(id: string): StorageTableInstance;\n safeParse(id: string): StorageTableInstance | null;\n /** Decode a bucket id (`{stage}.{bucket}`) into a bucket-only instance. */\n parseBucket(id: string): StorageTableInstance;\n safeParseBucket(id: string): StorageTableInstance | null;\n createTable(input: Parameters<CreateTableFn>[0]): StorageTableInstance;\n createBucket(input: Parameters<CreateBucketFn>[0]): StorageTableInstance;\n\n // Business\n createDefaultBucket(input: { stage: BucketStage; name: string }): StorageTableInstance;\n /** Like `createDefaultBucket`, but returns null instead of throwing when the name sanitizes to an empty/invalid segment. */\n safeCreateDefaultBucket(input: { stage: BucketStage; name: string }): StorageTableInstance | null;\n createDefaultConfigBucket(input: {\n stage: BucketStage;\n componentId: string;\n configId: string;\n }): StorageTableInstance;\n createDefaultConfigTable(input: {\n stage: BucketStage;\n componentId: string;\n configId: string;\n tableName: string;\n }): StorageTableInstance;\n createDefaultCsvImportTable(configId: string): StorageTableInstance;\n};\n\nexport const createStorageTable = (flags: ModelOptions): StorageTable => {\n const model = createTableModel(flags);\n\n const branchIt = (bucket: Bucket, branchId: string): Bucket =>\n bucket.kind !== 'legacy' ? bucket : { ...bucket, branchId };\n\n const unbranchIt = (bucket: Bucket, branchId: string): Bucket =>\n bucket.kind !== 'legacy' || bucket.branchId !== branchId\n ? bucket\n : { ...bucket, branchId: null };\n\n const make = (bucket: Bucket, tableName: TableName | null): StorageTableInstance => {\n const self: StorageTableInstance = {\n bucket,\n name: tableName,\n isInBranch: (branchId) => bucket.kind === 'legacy' && bucket.branchId === branchId,\n addBranch: (branchId) => {\n if (branchId.length === 0) throw new Error('branchId is required');\n return make(branchIt(bucket, branchId), tableName);\n },\n removeBranch: (branchId) => {\n if (branchId.length === 0) throw new Error('branchId is required');\n return make(unbranchIt(bucket, branchId), tableName);\n },\n addTableName: (name) => {\n if (name.length === 0) throw new Error('tableName is required');\n return make(bucket, name);\n },\n\n getBucketName: () => model.serializeBucketName(bucket),\n getBucketDisplayName: () => model.serializeBucketDisplayName(bucket),\n getBucketBaseName: () => bucket.baseName,\n getTableName: () => {\n if (tableName === null)\n throw new Error(\n 'getTableName() requires a table name — instance was built via createBucket',\n );\n return tableName;\n },\n\n getBucketId: () => model.serializeBucketId(bucket),\n getTableId: () => model.serializeTableId({ bucket, name: tableName ?? '' }),\n\n getSafeBucketId: () => model.safeSerializeBucketId(bucket),\n getSafeTableId: () => model.safeSerializeTableId({ bucket, name: tableName ?? '' }),\n };\n\n return self;\n };\n\n const parse = (id: TableId) => {\n const table = model.parse(id);\n return make(table.bucket, table.name);\n };\n const safeParse = (id: TableId) => {\n const table = model.safeParse(id);\n return table ? make(table.bucket, table.name) : null;\n };\n\n const parseBucket = (id: BucketId) => make(model.parseBucket(id), null);\n\n const safeParseBucket = (id: BucketId) => {\n const bucket = model.safeParseBucket(id);\n return bucket ? make(bucket, null) : null;\n };\n\n const createTable = (input: Parameters<CreateTableFn>[0]) => {\n const { bucket, name } = model.createTable(input);\n return make(bucket, name);\n };\n\n const createBucket = (input: Parameters<CreateBucketFn>[0]): StorageTableInstance =>\n make(model.createBucket(input), null);\n\n return {\n // generic\n parse,\n safeParse,\n parseBucket,\n safeParseBucket,\n createTable,\n createBucket,\n\n // Business\n createDefaultCsvImportTable: (configId: string) => {\n const bucketName = flags.useLegacyBucketPrefix\n ? 'c-csv-import'\n : webalize(`keboola.csv-import-${configId}`);\n const tableName = flags.useLegacyBucketPrefix ? configId : 'data';\n\n return createTable({\n stage: 'in',\n tableName,\n bucketName,\n });\n },\n createDefaultBucket: ({ stage, name }) => createBucket({ stage, name: webalize(name) }),\n safeCreateDefaultBucket: ({ stage, name }) => {\n try {\n return createBucket({ stage, name: webalize(name) });\n } catch {\n // webalize() throws when the input sanitizes to an empty name segment — surface as null per the safe-* contract\n return null;\n }\n },\n createDefaultConfigBucket: ({ stage, componentId, configId }) =>\n createBucket({ stage, name: webalize(`${componentId}-${configId}`) }),\n createDefaultConfigTable: ({ stage, componentId, configId, tableName }) =>\n createTable({ stage, bucketName: webalize(`${componentId}-${configId}`), tableName }),\n };\n};\n"]}
@@ -0,0 +1,131 @@
1
+ type BucketStage = 'in' | 'out';
2
+ type BucketName = string;
3
+ type TableName = string;
4
+ type BucketId = `${BucketStage}.${BucketName}`;
5
+ type TableId = `${BucketId}.${TableName}`;
6
+ type TableIdParts = [stage: BucketStage, bucket: BucketName, table: TableName];
7
+ type StorageBranchBucket = {
8
+ kind: 'storage-branch';
9
+ /**
10
+ * The bare name: no `c-` prefix. Branches are BE-side, so there is no `{branchId}-` decoration. e.g. `main`.
11
+ * The on-disk form is derived from it by adding the legacy `c-` prefix:
12
+ * name (on-disk) = `c-{baseName}` (adds `c-` when hasLegacyPrefix)
13
+ */
14
+ baseName: BucketName;
15
+ /** When true, the on-disk name carries the legacy `c-` prefix. */
16
+ hasLegacyPrefix: boolean;
17
+ };
18
+ type LegacyBucket = {
19
+ kind: 'legacy';
20
+ /**
21
+ * The bare name: no `c-` prefix, no `{branchId}-` prefix. e.g. `main`.
22
+ * The two on-disk forms are derived from it by adding decoration:
23
+ * branchedName = `{branchId}-{baseName}` (drops `c-`, keeps branch — user-facing)
24
+ * name (on-disk) = `c-{branchedName}` (adds `c-` when hasLegacyPrefix)
25
+ */
26
+ baseName: BucketName;
27
+ /** When true, the on-disk name carries the legacy `c-` prefix. */
28
+ hasLegacyPrefix: boolean;
29
+ /** Dev-branch id encoded into the on-disk name, if any. */
30
+ branchId: string | null;
31
+ };
32
+ type ParsedBucket = StorageBranchBucket | LegacyBucket;
33
+ type Bucket = ParsedBucket & {
34
+ stage: BucketStage;
35
+ };
36
+ type Table = {
37
+ name: TableName;
38
+ bucket: Bucket;
39
+ };
40
+ type ModelOptions = {
41
+ /** Project uses the legacy `c-` bucket prefix. (kbc-ui: `!FEATURE_DISABLE_LEGACY_BUCKET_PREFIX`) */
42
+ useLegacyBucketPrefix: boolean;
43
+ /** `FEATURE_SOX_PROTECTED_DEFAULT_BRANCH` */
44
+ hasProtectedDefaultBranch: boolean;
45
+ /** `FEATURE_STORAGE_BRANCHES` */
46
+ hasStorageBranches: boolean;
47
+ };
48
+
49
+ type CreateBucketFn = (input: {
50
+ stage: BucketStage;
51
+ name: BucketName;
52
+ branchId?: string | null;
53
+ }) => Bucket;
54
+ type CreateTableFn = (input: {
55
+ stage: BucketStage;
56
+ tableName: TableName;
57
+ bucketName: BucketName;
58
+ branchId?: string | null;
59
+ }) => Table;
60
+ type TableModel = {
61
+ parse(id: string): Table;
62
+ parseBucket(id: string): Bucket;
63
+ safeParse(id: string): Table | null;
64
+ safeParseBucket(id: string): Bucket | null;
65
+ serializeTableId(table: Table): TableId;
66
+ serializeBucketId(bucket: Bucket): BucketId;
67
+ serializeBucketName(bucket: Bucket): BucketName;
68
+ serializeBucketDisplayName(bucket: Bucket): BucketName;
69
+ safeSerializeTableId(table: Table): TableId | null;
70
+ safeSerializeBucketId(bucket: Bucket): BucketId | null;
71
+ safeSerializeBucketName(bucket: Bucket): BucketName | null;
72
+ createTable: CreateTableFn;
73
+ createBucket: CreateBucketFn;
74
+ };
75
+ declare const createTableModel: (options: ModelOptions) => TableModel;
76
+
77
+ type StorageTableInstance = {
78
+ readonly bucket: Bucket;
79
+ readonly name: TableName | null;
80
+ isInBranch(branchId: string): boolean;
81
+ addBranch(branchId: string): StorageTableInstance;
82
+ removeBranch(branchId: string): StorageTableInstance;
83
+ /** A new instance with the table name set (or replaced). */
84
+ addTableName(tableName: TableName): StorageTableInstance;
85
+ getBucketName(): BucketName;
86
+ /** Bucket name as shown to users: dev-branch prefix kept, legacy `c-` prefix always dropped. */
87
+ getBucketDisplayName(): BucketName;
88
+ /** Bare bucket name: no `c-` prefix, no dev-branch prefix (legacy `baseName`, or the canonical storage-branch name). */
89
+ getBucketBaseName(): BucketName;
90
+ getBucketId(): BucketId;
91
+ getSafeBucketId(): BucketId | null;
92
+ /** @throws when there is no table name (the instance was built via `createBucket`). */
93
+ getTableName(): TableName;
94
+ /** @throws when there is no table name (the instance was built via `createBucket`). */
95
+ getTableId(): TableId;
96
+ /** Null when there is no table name (built via `createBucket`) or a segment is empty. */
97
+ getSafeTableId(): TableId | null;
98
+ };
99
+ type StorageTable = {
100
+ parse(id: string): StorageTableInstance;
101
+ safeParse(id: string): StorageTableInstance | null;
102
+ /** Decode a bucket id (`{stage}.{bucket}`) into a bucket-only instance. */
103
+ parseBucket(id: string): StorageTableInstance;
104
+ safeParseBucket(id: string): StorageTableInstance | null;
105
+ createTable(input: Parameters<CreateTableFn>[0]): StorageTableInstance;
106
+ createBucket(input: Parameters<CreateBucketFn>[0]): StorageTableInstance;
107
+ createDefaultBucket(input: {
108
+ stage: BucketStage;
109
+ name: string;
110
+ }): StorageTableInstance;
111
+ /** Like `createDefaultBucket`, but returns null instead of throwing when the name sanitizes to an empty/invalid segment. */
112
+ safeCreateDefaultBucket(input: {
113
+ stage: BucketStage;
114
+ name: string;
115
+ }): StorageTableInstance | null;
116
+ createDefaultConfigBucket(input: {
117
+ stage: BucketStage;
118
+ componentId: string;
119
+ configId: string;
120
+ }): StorageTableInstance;
121
+ createDefaultConfigTable(input: {
122
+ stage: BucketStage;
123
+ componentId: string;
124
+ configId: string;
125
+ tableName: string;
126
+ }): StorageTableInstance;
127
+ createDefaultCsvImportTable(configId: string): StorageTableInstance;
128
+ };
129
+ declare const createStorageTable: (flags: ModelOptions) => StorageTable;
130
+
131
+ export { type Bucket, type BucketId, type BucketName, type BucketStage, type CreateBucketFn, type CreateTableFn, type LegacyBucket, type ModelOptions, type ParsedBucket, type StorageBranchBucket, type StorageTableInstance as StorageTable, type StorageTable as StorageTableScope, type Table, type TableId, type TableIdParts, type TableModel, type TableName, createStorageTable, createTableModel };
@@ -0,0 +1,131 @@
1
+ type BucketStage = 'in' | 'out';
2
+ type BucketName = string;
3
+ type TableName = string;
4
+ type BucketId = `${BucketStage}.${BucketName}`;
5
+ type TableId = `${BucketId}.${TableName}`;
6
+ type TableIdParts = [stage: BucketStage, bucket: BucketName, table: TableName];
7
+ type StorageBranchBucket = {
8
+ kind: 'storage-branch';
9
+ /**
10
+ * The bare name: no `c-` prefix. Branches are BE-side, so there is no `{branchId}-` decoration. e.g. `main`.
11
+ * The on-disk form is derived from it by adding the legacy `c-` prefix:
12
+ * name (on-disk) = `c-{baseName}` (adds `c-` when hasLegacyPrefix)
13
+ */
14
+ baseName: BucketName;
15
+ /** When true, the on-disk name carries the legacy `c-` prefix. */
16
+ hasLegacyPrefix: boolean;
17
+ };
18
+ type LegacyBucket = {
19
+ kind: 'legacy';
20
+ /**
21
+ * The bare name: no `c-` prefix, no `{branchId}-` prefix. e.g. `main`.
22
+ * The two on-disk forms are derived from it by adding decoration:
23
+ * branchedName = `{branchId}-{baseName}` (drops `c-`, keeps branch — user-facing)
24
+ * name (on-disk) = `c-{branchedName}` (adds `c-` when hasLegacyPrefix)
25
+ */
26
+ baseName: BucketName;
27
+ /** When true, the on-disk name carries the legacy `c-` prefix. */
28
+ hasLegacyPrefix: boolean;
29
+ /** Dev-branch id encoded into the on-disk name, if any. */
30
+ branchId: string | null;
31
+ };
32
+ type ParsedBucket = StorageBranchBucket | LegacyBucket;
33
+ type Bucket = ParsedBucket & {
34
+ stage: BucketStage;
35
+ };
36
+ type Table = {
37
+ name: TableName;
38
+ bucket: Bucket;
39
+ };
40
+ type ModelOptions = {
41
+ /** Project uses the legacy `c-` bucket prefix. (kbc-ui: `!FEATURE_DISABLE_LEGACY_BUCKET_PREFIX`) */
42
+ useLegacyBucketPrefix: boolean;
43
+ /** `FEATURE_SOX_PROTECTED_DEFAULT_BRANCH` */
44
+ hasProtectedDefaultBranch: boolean;
45
+ /** `FEATURE_STORAGE_BRANCHES` */
46
+ hasStorageBranches: boolean;
47
+ };
48
+
49
+ type CreateBucketFn = (input: {
50
+ stage: BucketStage;
51
+ name: BucketName;
52
+ branchId?: string | null;
53
+ }) => Bucket;
54
+ type CreateTableFn = (input: {
55
+ stage: BucketStage;
56
+ tableName: TableName;
57
+ bucketName: BucketName;
58
+ branchId?: string | null;
59
+ }) => Table;
60
+ type TableModel = {
61
+ parse(id: string): Table;
62
+ parseBucket(id: string): Bucket;
63
+ safeParse(id: string): Table | null;
64
+ safeParseBucket(id: string): Bucket | null;
65
+ serializeTableId(table: Table): TableId;
66
+ serializeBucketId(bucket: Bucket): BucketId;
67
+ serializeBucketName(bucket: Bucket): BucketName;
68
+ serializeBucketDisplayName(bucket: Bucket): BucketName;
69
+ safeSerializeTableId(table: Table): TableId | null;
70
+ safeSerializeBucketId(bucket: Bucket): BucketId | null;
71
+ safeSerializeBucketName(bucket: Bucket): BucketName | null;
72
+ createTable: CreateTableFn;
73
+ createBucket: CreateBucketFn;
74
+ };
75
+ declare const createTableModel: (options: ModelOptions) => TableModel;
76
+
77
+ type StorageTableInstance = {
78
+ readonly bucket: Bucket;
79
+ readonly name: TableName | null;
80
+ isInBranch(branchId: string): boolean;
81
+ addBranch(branchId: string): StorageTableInstance;
82
+ removeBranch(branchId: string): StorageTableInstance;
83
+ /** A new instance with the table name set (or replaced). */
84
+ addTableName(tableName: TableName): StorageTableInstance;
85
+ getBucketName(): BucketName;
86
+ /** Bucket name as shown to users: dev-branch prefix kept, legacy `c-` prefix always dropped. */
87
+ getBucketDisplayName(): BucketName;
88
+ /** Bare bucket name: no `c-` prefix, no dev-branch prefix (legacy `baseName`, or the canonical storage-branch name). */
89
+ getBucketBaseName(): BucketName;
90
+ getBucketId(): BucketId;
91
+ getSafeBucketId(): BucketId | null;
92
+ /** @throws when there is no table name (the instance was built via `createBucket`). */
93
+ getTableName(): TableName;
94
+ /** @throws when there is no table name (the instance was built via `createBucket`). */
95
+ getTableId(): TableId;
96
+ /** Null when there is no table name (built via `createBucket`) or a segment is empty. */
97
+ getSafeTableId(): TableId | null;
98
+ };
99
+ type StorageTable = {
100
+ parse(id: string): StorageTableInstance;
101
+ safeParse(id: string): StorageTableInstance | null;
102
+ /** Decode a bucket id (`{stage}.{bucket}`) into a bucket-only instance. */
103
+ parseBucket(id: string): StorageTableInstance;
104
+ safeParseBucket(id: string): StorageTableInstance | null;
105
+ createTable(input: Parameters<CreateTableFn>[0]): StorageTableInstance;
106
+ createBucket(input: Parameters<CreateBucketFn>[0]): StorageTableInstance;
107
+ createDefaultBucket(input: {
108
+ stage: BucketStage;
109
+ name: string;
110
+ }): StorageTableInstance;
111
+ /** Like `createDefaultBucket`, but returns null instead of throwing when the name sanitizes to an empty/invalid segment. */
112
+ safeCreateDefaultBucket(input: {
113
+ stage: BucketStage;
114
+ name: string;
115
+ }): StorageTableInstance | null;
116
+ createDefaultConfigBucket(input: {
117
+ stage: BucketStage;
118
+ componentId: string;
119
+ configId: string;
120
+ }): StorageTableInstance;
121
+ createDefaultConfigTable(input: {
122
+ stage: BucketStage;
123
+ componentId: string;
124
+ configId: string;
125
+ tableName: string;
126
+ }): StorageTableInstance;
127
+ createDefaultCsvImportTable(configId: string): StorageTableInstance;
128
+ };
129
+ declare const createStorageTable: (flags: ModelOptions) => StorageTable;
130
+
131
+ export { type Bucket, type BucketId, type BucketName, type BucketStage, type CreateBucketFn, type CreateTableFn, type LegacyBucket, type ModelOptions, type ParsedBucket, type StorageBranchBucket, type StorageTableInstance as StorageTable, type StorageTable as StorageTableScope, type Table, type TableId, type TableIdParts, type TableModel, type TableName, createStorageTable, createTableModel };