@s2-dev/streamstore 0.20.0 → 0.21.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 (221) hide show
  1. package/LICENSE +21 -201
  2. package/README.md +60 -10
  3. package/dist/cjs/accessTokens.d.ts +27 -14
  4. package/dist/cjs/accessTokens.d.ts.map +1 -1
  5. package/dist/cjs/accessTokens.js +72 -8
  6. package/dist/cjs/accessTokens.js.map +1 -1
  7. package/dist/cjs/basins.d.ts +29 -19
  8. package/dist/cjs/basins.d.ts.map +1 -1
  9. package/dist/cjs/basins.js +119 -9
  10. package/dist/cjs/basins.js.map +1 -1
  11. package/dist/cjs/batch-transform.d.ts +12 -16
  12. package/dist/cjs/batch-transform.d.ts.map +1 -1
  13. package/dist/cjs/batch-transform.js +17 -21
  14. package/dist/cjs/batch-transform.js.map +1 -1
  15. package/dist/cjs/common.d.ts +31 -24
  16. package/dist/cjs/common.d.ts.map +1 -1
  17. package/dist/cjs/common.js +22 -0
  18. package/dist/cjs/common.js.map +1 -1
  19. package/dist/cjs/endpoints.d.ts +63 -0
  20. package/dist/cjs/endpoints.d.ts.map +1 -0
  21. package/dist/cjs/endpoints.js +120 -0
  22. package/dist/cjs/endpoints.js.map +1 -0
  23. package/dist/cjs/error.d.ts.map +1 -1
  24. package/dist/cjs/error.js +11 -0
  25. package/dist/cjs/error.js.map +1 -1
  26. package/dist/cjs/generated/types.gen.d.ts +11 -20
  27. package/dist/cjs/generated/types.gen.d.ts.map +1 -1
  28. package/dist/cjs/index.d.ts +30 -46
  29. package/dist/cjs/index.d.ts.map +1 -1
  30. package/dist/cjs/index.js +50 -26
  31. package/dist/cjs/index.js.map +1 -1
  32. package/dist/cjs/internal/case-transform.d.ts +59 -0
  33. package/dist/cjs/internal/case-transform.d.ts.map +1 -0
  34. package/dist/cjs/internal/case-transform.js +80 -0
  35. package/dist/cjs/internal/case-transform.js.map +1 -0
  36. package/dist/cjs/internal/mappers.d.ts +51 -0
  37. package/dist/cjs/internal/mappers.d.ts.map +1 -0
  38. package/dist/cjs/internal/mappers.js +225 -0
  39. package/dist/cjs/internal/mappers.js.map +1 -0
  40. package/dist/cjs/internal/sdk-types.d.ts +127 -0
  41. package/dist/cjs/internal/sdk-types.d.ts.map +1 -0
  42. package/dist/cjs/internal/sdk-types.js +9 -0
  43. package/dist/cjs/internal/sdk-types.js.map +1 -0
  44. package/dist/cjs/lib/base64.d.ts +8 -0
  45. package/dist/cjs/lib/base64.d.ts.map +1 -1
  46. package/dist/cjs/lib/base64.js +32 -12
  47. package/dist/cjs/lib/base64.js.map +1 -1
  48. package/dist/cjs/lib/event-stream.d.ts.map +1 -1
  49. package/dist/cjs/lib/event-stream.js +2 -1
  50. package/dist/cjs/lib/event-stream.js.map +1 -1
  51. package/dist/cjs/lib/paginate.d.ts +57 -0
  52. package/dist/cjs/lib/paginate.d.ts.map +1 -0
  53. package/dist/cjs/lib/paginate.js +51 -0
  54. package/dist/cjs/lib/paginate.js.map +1 -0
  55. package/dist/cjs/lib/result.d.ts +1 -1
  56. package/dist/cjs/lib/result.d.ts.map +1 -1
  57. package/dist/cjs/lib/retry.d.ts +47 -31
  58. package/dist/cjs/lib/retry.d.ts.map +1 -1
  59. package/dist/cjs/lib/retry.js +302 -201
  60. package/dist/cjs/lib/retry.js.map +1 -1
  61. package/dist/cjs/lib/stream/runtime.d.ts +1 -1
  62. package/dist/cjs/lib/stream/transport/fetch/index.d.ts +7 -9
  63. package/dist/cjs/lib/stream/transport/fetch/index.d.ts.map +1 -1
  64. package/dist/cjs/lib/stream/transport/fetch/index.js +38 -39
  65. package/dist/cjs/lib/stream/transport/fetch/index.js.map +1 -1
  66. package/dist/cjs/lib/stream/transport/fetch/shared.d.ts +7 -2
  67. package/dist/cjs/lib/stream/transport/fetch/shared.d.ts.map +1 -1
  68. package/dist/cjs/lib/stream/transport/fetch/shared.js +56 -110
  69. package/dist/cjs/lib/stream/transport/fetch/shared.js.map +1 -1
  70. package/dist/cjs/lib/stream/transport/proto.d.ts +9 -0
  71. package/dist/cjs/lib/stream/transport/proto.d.ts.map +1 -0
  72. package/dist/cjs/lib/stream/transport/proto.js +118 -0
  73. package/dist/cjs/lib/stream/transport/proto.js.map +1 -0
  74. package/dist/cjs/lib/stream/transport/s2s/index.d.ts +3 -3
  75. package/dist/cjs/lib/stream/transport/s2s/index.d.ts.map +1 -1
  76. package/dist/cjs/lib/stream/transport/s2s/index.js +115 -82
  77. package/dist/cjs/lib/stream/transport/s2s/index.js.map +1 -1
  78. package/dist/cjs/lib/stream/types.d.ts +81 -36
  79. package/dist/cjs/lib/stream/types.d.ts.map +1 -1
  80. package/dist/cjs/lib/stream/types.js +18 -0
  81. package/dist/cjs/lib/stream/types.js.map +1 -1
  82. package/dist/cjs/metrics.d.ts +18 -17
  83. package/dist/cjs/metrics.d.ts.map +1 -1
  84. package/dist/cjs/metrics.js +67 -12
  85. package/dist/cjs/metrics.js.map +1 -1
  86. package/dist/cjs/producer.d.ts +82 -0
  87. package/dist/cjs/producer.d.ts.map +1 -0
  88. package/dist/cjs/producer.js +305 -0
  89. package/dist/cjs/producer.js.map +1 -0
  90. package/dist/cjs/s2.d.ts +1 -2
  91. package/dist/cjs/s2.d.ts.map +1 -1
  92. package/dist/cjs/s2.js +9 -9
  93. package/dist/cjs/s2.js.map +1 -1
  94. package/dist/cjs/stream.d.ts +26 -12
  95. package/dist/cjs/stream.d.ts.map +1 -1
  96. package/dist/cjs/stream.js +77 -13
  97. package/dist/cjs/stream.js.map +1 -1
  98. package/dist/cjs/streams.d.ts +29 -19
  99. package/dist/cjs/streams.d.ts.map +1 -1
  100. package/dist/cjs/streams.js +120 -9
  101. package/dist/cjs/streams.js.map +1 -1
  102. package/dist/cjs/types.d.ts +624 -0
  103. package/dist/cjs/types.d.ts.map +1 -0
  104. package/dist/cjs/types.js +129 -0
  105. package/dist/cjs/types.js.map +1 -0
  106. package/dist/cjs/utils.d.ts +1 -22
  107. package/dist/cjs/utils.d.ts.map +1 -1
  108. package/dist/cjs/utils.js +0 -42
  109. package/dist/cjs/utils.js.map +1 -1
  110. package/dist/cjs/version.d.ts +1 -1
  111. package/dist/cjs/version.js +1 -1
  112. package/dist/esm/accessTokens.d.ts +27 -14
  113. package/dist/esm/accessTokens.d.ts.map +1 -1
  114. package/dist/esm/accessTokens.js +73 -9
  115. package/dist/esm/accessTokens.js.map +1 -1
  116. package/dist/esm/basins.d.ts +29 -19
  117. package/dist/esm/basins.d.ts.map +1 -1
  118. package/dist/esm/basins.js +119 -9
  119. package/dist/esm/basins.js.map +1 -1
  120. package/dist/esm/batch-transform.d.ts +12 -16
  121. package/dist/esm/batch-transform.d.ts.map +1 -1
  122. package/dist/esm/batch-transform.js +18 -22
  123. package/dist/esm/batch-transform.js.map +1 -1
  124. package/dist/esm/common.d.ts +31 -24
  125. package/dist/esm/common.d.ts.map +1 -1
  126. package/dist/esm/common.js +20 -1
  127. package/dist/esm/common.js.map +1 -1
  128. package/dist/esm/endpoints.d.ts +63 -0
  129. package/dist/esm/endpoints.d.ts.map +1 -0
  130. package/dist/esm/endpoints.js +115 -0
  131. package/dist/esm/endpoints.js.map +1 -0
  132. package/dist/esm/error.d.ts.map +1 -1
  133. package/dist/esm/error.js +11 -0
  134. package/dist/esm/error.js.map +1 -1
  135. package/dist/esm/generated/types.gen.d.ts +11 -20
  136. package/dist/esm/generated/types.gen.d.ts.map +1 -1
  137. package/dist/esm/index.d.ts +30 -46
  138. package/dist/esm/index.d.ts.map +1 -1
  139. package/dist/esm/index.js +33 -19
  140. package/dist/esm/index.js.map +1 -1
  141. package/dist/esm/internal/case-transform.d.ts +59 -0
  142. package/dist/esm/internal/case-transform.d.ts.map +1 -0
  143. package/dist/esm/internal/case-transform.js +76 -0
  144. package/dist/esm/internal/case-transform.js.map +1 -0
  145. package/dist/esm/internal/mappers.d.ts +51 -0
  146. package/dist/esm/internal/mappers.d.ts.map +1 -0
  147. package/dist/esm/internal/mappers.js +218 -0
  148. package/dist/esm/internal/mappers.js.map +1 -0
  149. package/dist/esm/internal/sdk-types.d.ts +127 -0
  150. package/dist/esm/internal/sdk-types.d.ts.map +1 -0
  151. package/dist/esm/internal/sdk-types.js +8 -0
  152. package/dist/esm/internal/sdk-types.js.map +1 -0
  153. package/dist/esm/lib/base64.d.ts +8 -0
  154. package/dist/esm/lib/base64.d.ts.map +1 -1
  155. package/dist/esm/lib/base64.js +30 -11
  156. package/dist/esm/lib/base64.js.map +1 -1
  157. package/dist/esm/lib/event-stream.d.ts.map +1 -1
  158. package/dist/esm/lib/event-stream.js +2 -1
  159. package/dist/esm/lib/event-stream.js.map +1 -1
  160. package/dist/esm/lib/paginate.d.ts +57 -0
  161. package/dist/esm/lib/paginate.d.ts.map +1 -0
  162. package/dist/esm/lib/paginate.js +48 -0
  163. package/dist/esm/lib/paginate.js.map +1 -0
  164. package/dist/esm/lib/result.d.ts +1 -1
  165. package/dist/esm/lib/result.d.ts.map +1 -1
  166. package/dist/esm/lib/retry.d.ts +47 -31
  167. package/dist/esm/lib/retry.d.ts.map +1 -1
  168. package/dist/esm/lib/retry.js +303 -201
  169. package/dist/esm/lib/retry.js.map +1 -1
  170. package/dist/esm/lib/stream/runtime.d.ts +1 -1
  171. package/dist/esm/lib/stream/transport/fetch/index.d.ts +7 -9
  172. package/dist/esm/lib/stream/transport/fetch/index.d.ts.map +1 -1
  173. package/dist/esm/lib/stream/transport/fetch/index.js +40 -41
  174. package/dist/esm/lib/stream/transport/fetch/index.js.map +1 -1
  175. package/dist/esm/lib/stream/transport/fetch/shared.d.ts +7 -2
  176. package/dist/esm/lib/stream/transport/fetch/shared.d.ts.map +1 -1
  177. package/dist/esm/lib/stream/transport/fetch/shared.js +58 -112
  178. package/dist/esm/lib/stream/transport/fetch/shared.js.map +1 -1
  179. package/dist/esm/lib/stream/transport/proto.d.ts +9 -0
  180. package/dist/esm/lib/stream/transport/proto.d.ts.map +1 -0
  181. package/dist/esm/lib/stream/transport/proto.js +110 -0
  182. package/dist/esm/lib/stream/transport/proto.js.map +1 -0
  183. package/dist/esm/lib/stream/transport/s2s/index.d.ts +3 -3
  184. package/dist/esm/lib/stream/transport/s2s/index.d.ts.map +1 -1
  185. package/dist/esm/lib/stream/transport/s2s/index.js +116 -82
  186. package/dist/esm/lib/stream/transport/s2s/index.js.map +1 -1
  187. package/dist/esm/lib/stream/types.d.ts +81 -36
  188. package/dist/esm/lib/stream/types.d.ts.map +1 -1
  189. package/dist/esm/lib/stream/types.js +17 -1
  190. package/dist/esm/lib/stream/types.js.map +1 -1
  191. package/dist/esm/metrics.d.ts +18 -17
  192. package/dist/esm/metrics.d.ts.map +1 -1
  193. package/dist/esm/metrics.js +66 -12
  194. package/dist/esm/metrics.js.map +1 -1
  195. package/dist/esm/producer.d.ts +82 -0
  196. package/dist/esm/producer.d.ts.map +1 -0
  197. package/dist/esm/producer.js +300 -0
  198. package/dist/esm/producer.js.map +1 -0
  199. package/dist/esm/s2.d.ts +1 -2
  200. package/dist/esm/s2.d.ts.map +1 -1
  201. package/dist/esm/s2.js +9 -9
  202. package/dist/esm/s2.js.map +1 -1
  203. package/dist/esm/stream.d.ts +26 -12
  204. package/dist/esm/stream.d.ts.map +1 -1
  205. package/dist/esm/stream.js +79 -15
  206. package/dist/esm/stream.js.map +1 -1
  207. package/dist/esm/streams.d.ts +29 -19
  208. package/dist/esm/streams.d.ts.map +1 -1
  209. package/dist/esm/streams.js +120 -9
  210. package/dist/esm/streams.js.map +1 -1
  211. package/dist/esm/types.d.ts +624 -0
  212. package/dist/esm/types.d.ts.map +1 -0
  213. package/dist/esm/types.js +126 -0
  214. package/dist/esm/types.js.map +1 -0
  215. package/dist/esm/utils.d.ts +1 -22
  216. package/dist/esm/utils.d.ts.map +1 -1
  217. package/dist/esm/utils.js +0 -41
  218. package/dist/esm/utils.js.map +1 -1
  219. package/dist/esm/version.d.ts +1 -1
  220. package/dist/esm/version.js +1 -1
  221. package/package.json +4 -3
@@ -1,9 +1,11 @@
1
1
  import { makeAppendPreconditionError, makeServerError, RangeNotSatisfiableError, S2Error, s2Error, } from "../../../../error.js";
2
- import { append, checkTail, read, } from "../../../../generated/index.js";
3
- import { computeAppendRecordFormat, meteredBytes } from "../../../../utils.js";
4
- import { decodeFromBase64, encodeToBase64 } from "../../../base64.js";
2
+ import { append, read } from "../../../../generated/index.js";
3
+ import { fromAPIAppendAck, toAPIAppendRecord, } from "../../../../internal/mappers.js";
4
+ import { computeAppendRecordFormat } from "../../../../utils.js";
5
+ import { decodeProtoAppendAck, decodeProtoReadBatch, encodeProtoAppendInput, protoAppendAckToJson, } from "../proto.js";
5
6
  export async function streamRead(stream, client, args, options) {
6
7
  const { as, ...queryParams } = args ?? {};
8
+ const wantsBytes = (as ?? "string") === "bytes";
7
9
  let response;
8
10
  try {
9
11
  response = await read({
@@ -11,10 +13,9 @@ export async function streamRead(stream, client, args, options) {
11
13
  path: {
12
14
  stream,
13
15
  },
14
- headers: {
15
- ...(as === "bytes" ? { "s2-format": "base64" } : {}),
16
- },
16
+ headers: wantsBytes ? { Accept: "application/protobuf" } : undefined,
17
17
  query: queryParams,
18
+ parseAs: wantsBytes ? "arrayBuffer" : undefined,
18
19
  ...options,
19
20
  });
20
21
  }
@@ -28,111 +29,59 @@ export async function streamRead(stream, client, args, options) {
28
29
  }
29
30
  throw makeServerError({ status, statusText: response.response.statusText }, response.error);
30
31
  }
31
- if (args?.as === "bytes") {
32
- const res = {
33
- ...response.data,
34
- records: response.data.records?.map((record) => ({
35
- ...record,
36
- body: record.body ? decodeFromBase64(record.body) : undefined,
37
- headers: record.headers?.map((header) => header.map((h) => decodeFromBase64(h))),
38
- })) ?? [],
39
- };
40
- return res;
41
- }
42
- else {
43
- const res = {
44
- ...response.data,
45
- records: response.data.records?.map((record) => ({
46
- ...record,
47
- headers: record.headers
48
- ? Object.fromEntries(record.headers)
49
- : undefined,
50
- })) ?? [],
51
- };
52
- return res;
32
+ if (wantsBytes) {
33
+ const batch = decodeProtoReadBatch(response.data);
34
+ return batch;
53
35
  }
36
+ const res = {
37
+ ...response.data,
38
+ records: response.data.records?.map((record) => ({
39
+ ...record,
40
+ headers: record.headers
41
+ ? Object.fromEntries(record.headers)
42
+ : undefined,
43
+ })) ?? [],
44
+ };
45
+ return res;
54
46
  }
55
- export async function streamAppend(stream, client, records, args, options) {
56
- const recordsArray = Array.isArray(records) ? records : [records];
57
- if (recordsArray.length === 0) {
58
- throw new S2Error({ message: "Cannot append empty array of records" });
59
- }
60
- let batchMeteredSize = 0;
61
- for (const record of recordsArray) {
62
- batchMeteredSize += meteredBytes(record);
63
- }
64
- if (batchMeteredSize > 1024 * 1024) {
65
- throw new S2Error({
66
- message: `Batch size ${batchMeteredSize} bytes exceeds maximum of 1 MiB (1048576 bytes)`,
67
- });
68
- }
69
- if (recordsArray.length > 1000) {
70
- throw new S2Error({
71
- message: `Batch of ${recordsArray.length} exceeds maximum batch size of 1000 records`,
72
- });
73
- }
74
- let encodedRecords = [];
75
- let hasAnyBytesRecords = false;
76
- // First pass: determine if any records are bytes format
77
- for (const record of recordsArray) {
78
- const format = computeAppendRecordFormat(record);
79
- if (format === "bytes") {
80
- hasAnyBytesRecords = true;
81
- break;
47
+ export async function streamAppend(stream, client, input, options) {
48
+ const { preferProtobuf, ...requestOptions } = options ?? {};
49
+ const hasAnyBytesRecords = input.records.some((record) => computeAppendRecordFormat(record) === "bytes");
50
+ const useProtobuf = hasAnyBytesRecords || preferProtobuf === true;
51
+ let response;
52
+ if (useProtobuf) {
53
+ const protoBody = encodeProtoAppendInput(input);
54
+ const headers = {
55
+ Accept: "application/protobuf",
56
+ "Content-Type": "application/protobuf",
57
+ };
58
+ try {
59
+ response = await append({
60
+ client,
61
+ path: {
62
+ stream,
63
+ },
64
+ body: protoBody,
65
+ bodySerializer: null,
66
+ parseAs: "arrayBuffer",
67
+ headers,
68
+ ...requestOptions,
69
+ });
82
70
  }
83
- }
84
- const textEncoder = new TextEncoder();
85
- // Second pass: encode all records appropriately
86
- for (const record of recordsArray) {
87
- const format = computeAppendRecordFormat(record);
88
- if (format === "bytes") {
89
- const formattedRecord = record;
90
- const encodedRecord = {
91
- ...formattedRecord,
92
- body: formattedRecord.body
93
- ? encodeToBase64(formattedRecord.body)
94
- : undefined,
95
- headers: formattedRecord.headers?.map((header) => header.map((h) => encodeToBase64(h))),
96
- };
97
- encodedRecords.push(encodedRecord);
71
+ catch (error) {
72
+ throw s2Error(error);
98
73
  }
99
- else {
100
- // Normalize headers to array format
101
- const normalizeHeaders = (headers) => {
102
- if (headers === undefined) {
103
- return undefined;
104
- }
105
- else if (Array.isArray(headers)) {
106
- return headers;
107
- }
108
- else {
109
- return Object.entries(headers);
110
- }
111
- };
112
- const formattedRecord = record;
113
- const normalizedHeaders = formattedRecord.headers
114
- ? normalizeHeaders(formattedRecord.headers)
115
- : undefined;
116
- const encodedHeaders = normalizedHeaders
117
- ? hasAnyBytesRecords
118
- ? normalizedHeaders.map(([name, value]) => [
119
- encodeToBase64(textEncoder.encode(name)),
120
- encodeToBase64(textEncoder.encode(value)),
121
- ])
122
- : normalizedHeaders
123
- : undefined;
124
- // If batch has bytes records, encode string bodies as base64 too
125
- const encodedRecord = {
126
- ...formattedRecord,
127
- body: hasAnyBytesRecords && formattedRecord.body
128
- ? encodeToBase64(textEncoder.encode(formattedRecord.body))
129
- : formattedRecord.body,
130
- headers: encodedHeaders,
131
- };
132
- encodedRecords.push(encodedRecord);
74
+ if (response.error) {
75
+ const status = response.response.status;
76
+ if (status === 412) {
77
+ throw makeAppendPreconditionError(status, response.error);
78
+ }
79
+ throw makeServerError({ status, statusText: response.response.statusText }, response.error);
133
80
  }
81
+ const ack = decodeProtoAppendAck(response.data);
82
+ return protoAppendAckToJson(ack);
134
83
  }
135
- let response;
84
+ const encodedRecords = [...input.records].map(toAPIAppendRecord);
136
85
  try {
137
86
  response = await append({
138
87
  client,
@@ -140,14 +89,11 @@ export async function streamAppend(stream, client, records, args, options) {
140
89
  stream,
141
90
  },
142
91
  body: {
143
- fencing_token: args?.fencing_token,
144
- match_seq_num: args?.match_seq_num,
92
+ fencing_token: input.fencingToken,
93
+ match_seq_num: input.matchSeqNum,
145
94
  records: encodedRecords,
146
95
  },
147
- headers: {
148
- ...(hasAnyBytesRecords ? { "s2-format": "base64" } : {}),
149
- },
150
- ...options,
96
+ ...requestOptions,
151
97
  });
152
98
  }
153
99
  catch (error) {
@@ -160,6 +106,6 @@ export async function streamAppend(stream, client, records, args, options) {
160
106
  }
161
107
  throw makeServerError({ status, statusText: response.response.statusText }, response.error);
162
108
  }
163
- return response.data;
109
+ return fromAPIAppendAck(response.data);
164
110
  }
165
111
  //# sourceMappingURL=shared.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"shared.js","sourceRoot":"","sources":["../../../../../../src/lib/stream/transport/fetch/shared.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"shared.js","sourceRoot":"","sources":["../../../../../../src/lib/stream/transport/fetch/shared.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import * as Proto from "../../../generated/proto/s2.js";
2
+ import type * as Types from "../../../types.js";
3
+ import type { ReadBatch } from "../types.js";
4
+ export declare const buildProtoAppendInput: (input: Types.AppendInput) => Proto.AppendInput;
5
+ export declare const encodeProtoAppendInput: (input: Types.AppendInput) => Uint8Array;
6
+ export declare const decodeProtoAppendAck: (data: ArrayBuffer | Uint8Array) => Proto.AppendAck;
7
+ export declare const protoAppendAckToJson: (ack: Proto.AppendAck) => Types.AppendAck;
8
+ export declare const decodeProtoReadBatch: (data: ArrayBuffer | Uint8Array) => ReadBatch<"bytes">;
9
+ //# sourceMappingURL=proto.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"proto.d.ts","sourceRoot":"","sources":["../../../../../src/lib/stream/transport/proto.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,gCAAgC,CAAC;AACxD,OAAO,KAAK,KAAK,KAAK,MAAM,mBAAmB,CAAC;AAChD,OAAO,KAAK,EAAgB,SAAS,EAAE,MAAM,aAAa,CAAC;AAwF3D,eAAO,MAAM,qBAAqB,UAC1B,KAAK,CAAC,WAAW,KACtB,KAAK,CAAC,WAUR,CAAC;AAMF,eAAO,MAAM,sBAAsB,UAC3B,KAAK,CAAC,WAAW,KACtB,UAEF,CAAC;AAEF,eAAO,MAAM,oBAAoB,SAC1B,WAAW,GAAG,UAAU,KAC5B,KAAK,CAAC,SAER,CAAC;AAEF,eAAO,MAAM,oBAAoB,QAAS,KAAK,CAAC,SAAS,KAAG,KAAK,CAAC,SAkBjE,CAAC;AAEF,eAAO,MAAM,oBAAoB,SAC1B,WAAW,GAAG,UAAU,KAC5B,SAAS,CAAC,OAAO,CAUnB,CAAC"}
@@ -0,0 +1,110 @@
1
+ import { S2Error } from "../../../error.js";
2
+ import * as Proto from "../../../generated/proto/s2.js";
3
+ const textEncoder = new TextEncoder();
4
+ const MAX_SAFE_BIGINT = BigInt(Number.MAX_SAFE_INTEGER);
5
+ function bigintToSafeNumber(value, field) {
6
+ if (value > MAX_SAFE_BIGINT) {
7
+ throw new S2Error({
8
+ message: `${field} exceeds JavaScript Number.MAX_SAFE_INTEGER (${Number.MAX_SAFE_INTEGER}); use protobuf transport with bigint support or ensure values stay within 53-bit range`,
9
+ code: "UNSAFE_INTEGER",
10
+ status: 0,
11
+ origin: "sdk",
12
+ });
13
+ }
14
+ return Number(value);
15
+ }
16
+ const toBytes = (value) => {
17
+ if (value === undefined || value === null) {
18
+ return new Uint8Array();
19
+ }
20
+ return typeof value === "string" ? textEncoder.encode(value) : value;
21
+ };
22
+ const toProtoHeaders = (headers) => {
23
+ if (!headers) {
24
+ return [];
25
+ }
26
+ return headers.map(([name, value]) => ({
27
+ name: toBytes(name),
28
+ value: toBytes(value),
29
+ }));
30
+ };
31
+ const toProtoAppendRecord = (record) => {
32
+ let timestamp;
33
+ if (record.timestamp !== undefined) {
34
+ const ms = typeof record.timestamp === "number"
35
+ ? record.timestamp
36
+ : record.timestamp.getTime();
37
+ timestamp = BigInt(ms);
38
+ }
39
+ return {
40
+ timestamp,
41
+ headers: toProtoHeaders(record.headers),
42
+ body: toBytes(record.body),
43
+ };
44
+ };
45
+ const fromProtoPosition = (position) => {
46
+ if (!position) {
47
+ return undefined;
48
+ }
49
+ return {
50
+ seq_num: bigintToSafeNumber(position.seqNum, "StreamPosition.seqNum"),
51
+ timestamp: Number(position.timestamp),
52
+ };
53
+ };
54
+ const toSDKStreamPosition = (pos) => {
55
+ return {
56
+ seqNum: pos.seq_num,
57
+ timestamp: new Date(pos.timestamp),
58
+ };
59
+ };
60
+ const fromProtoSequencedRecord = (record) => {
61
+ return {
62
+ seq_num: bigintToSafeNumber(record.seqNum, "SequencedRecord.seqNum"),
63
+ timestamp: Number(record.timestamp),
64
+ headers: record.headers?.map((header) => [header.name, header.value]) ?? [],
65
+ body: record.body,
66
+ };
67
+ };
68
+ export const buildProtoAppendInput = (input) => {
69
+ return Proto.AppendInput.create({
70
+ records: [...input.records].map((record) => toProtoAppendRecord(record)),
71
+ fencingToken: input.fencingToken === null
72
+ ? undefined
73
+ : (input.fencingToken ?? undefined),
74
+ matchSeqNum: input.matchSeqNum !== undefined ? BigInt(input.matchSeqNum) : undefined,
75
+ });
76
+ };
77
+ const ensureUint8Array = (data) => {
78
+ return data instanceof Uint8Array ? data : new Uint8Array(data);
79
+ };
80
+ export const encodeProtoAppendInput = (input) => {
81
+ return Proto.AppendInput.toBinary(buildProtoAppendInput(input));
82
+ };
83
+ export const decodeProtoAppendAck = (data) => {
84
+ return Proto.AppendAck.fromBinary(ensureUint8Array(data));
85
+ };
86
+ export const protoAppendAckToJson = (ack) => {
87
+ const start = fromProtoPosition(ack.start);
88
+ const end = fromProtoPosition(ack.end);
89
+ if (!start || !end) {
90
+ throw new S2Error({
91
+ message: "AppendAck missing start or end positions",
92
+ status: 500,
93
+ origin: "sdk",
94
+ });
95
+ }
96
+ const tail = fromProtoPosition(ack.tail) ?? end;
97
+ return {
98
+ start: toSDKStreamPosition(start),
99
+ end: toSDKStreamPosition(end),
100
+ tail: toSDKStreamPosition(tail),
101
+ };
102
+ };
103
+ export const decodeProtoReadBatch = (data) => {
104
+ const protoBatch = Proto.ReadBatch.fromBinary(ensureUint8Array(data));
105
+ return {
106
+ records: protoBatch.records.map((record) => fromProtoSequencedRecord(record)),
107
+ tail: fromProtoPosition(protoBatch.tail),
108
+ };
109
+ };
110
+ //# sourceMappingURL=proto.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"proto.js","sourceRoot":"","sources":["../../../../../src/lib/stream/transport/proto.ts"],"names":[],"mappings":"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"}
@@ -5,13 +5,12 @@
5
5
  * This file should only be imported in Node.js environments
6
6
  */
7
7
  import type { S2RequestOptions } from "../../../../common.js";
8
- import { AppendInput as ProtoAppendInput } from "../../../../generated/proto/s2.js";
9
- import type { AppendArgs, AppendRecord, AppendSession, AppendSessionOptions, ReadArgs, ReadSession, SessionTransport, TransportConfig } from "../../types.js";
10
- export declare function buildProtoAppendInput(records: AppendRecord[], args: AppendArgs): ProtoAppendInput;
8
+ import type { AppendSession, AppendSessionOptions, ReadArgs, ReadSession, SessionTransport, TransportConfig } from "../../types.js";
11
9
  export declare class S2STransport implements SessionTransport {
12
10
  private readonly transportConfig;
13
11
  private connection?;
14
12
  private connectionPromise?;
13
+ private closingPromise?;
15
14
  constructor(config: TransportConfig);
16
15
  makeAppendSession(stream: string, sessionOptions?: AppendSessionOptions, requestOptions?: S2RequestOptions): Promise<AppendSession>;
17
16
  makeReadSession<Format extends "string" | "bytes" = "string">(stream: string, args?: ReadArgs<Format>, options?: S2RequestOptions): Promise<ReadSession<Format>>;
@@ -20,5 +19,6 @@ export declare class S2STransport implements SessionTransport {
20
19
  */
21
20
  private getConnection;
22
21
  private createConnection;
22
+ close(): Promise<void>;
23
23
  }
24
24
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/lib/stream/transport/s2s/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAQ9D,OAAO,EAEN,WAAW,IAAI,gBAAgB,EAG/B,MAAM,mCAAmC,CAAC;AAU3C,OAAO,KAAK,EACX,UAAU,EACV,YAAY,EACZ,aAAa,EACb,oBAAoB,EACpB,QAAQ,EAGR,WAAW,EACX,gBAAgB,EAEhB,eAAe,EAEf,MAAM,gBAAgB,CAAC;AAoBxB,wBAAgB,qBAAqB,CACpC,OAAO,EAAE,YAAY,EAAE,EACvB,IAAI,EAAE,UAAU,GACd,gBAAgB,CAgClB;AAED,qBAAa,YAAa,YAAW,gBAAgB;IACpD,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAkB;IAClD,OAAO,CAAC,UAAU,CAAC,CAAqB;IACxC,OAAO,CAAC,iBAAiB,CAAC,CAA8B;gBAE5C,MAAM,EAAE,eAAe;IAI7B,iBAAiB,CACtB,MAAM,EAAE,MAAM,EACd,cAAc,CAAC,EAAE,oBAAoB,EACrC,cAAc,CAAC,EAAE,gBAAgB,GAC/B,OAAO,CAAC,aAAa,CAAC;IAkBnB,eAAe,CAAC,MAAM,SAAS,QAAQ,GAAG,OAAO,GAAG,QAAQ,EACjE,MAAM,EAAE,MAAM,EACd,IAAI,CAAC,EAAE,QAAQ,CAAC,MAAM,CAAC,EACvB,OAAO,CAAC,EAAE,gBAAgB,GACxB,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IAkB/B;;OAEG;YACW,aAAa;YAyBb,gBAAgB;CAiC9B"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/lib/stream/transport/s2s/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAUH,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAmB9D,OAAO,KAAK,EAEX,aAAa,EACb,oBAAoB,EACpB,QAAQ,EAGR,WAAW,EACX,gBAAgB,EAEhB,eAAe,EAEf,MAAM,gBAAgB,CAAC;AAqBxB,qBAAa,YAAa,YAAW,gBAAgB;IACpD,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAkB;IAClD,OAAO,CAAC,UAAU,CAAC,CAAqB;IACxC,OAAO,CAAC,iBAAiB,CAAC,CAA8B;IACxD,OAAO,CAAC,cAAc,CAAC,CAAgB;gBAE3B,MAAM,EAAE,eAAe;IAI7B,iBAAiB,CACtB,MAAM,EAAE,MAAM,EACd,cAAc,CAAC,EAAE,oBAAoB,EACrC,cAAc,CAAC,EAAE,gBAAgB,GAC/B,OAAO,CAAC,aAAa,CAAC;IAmBnB,eAAe,CAAC,MAAM,SAAS,QAAQ,GAAG,OAAO,GAAG,QAAQ,EACjE,MAAM,EAAE,MAAM,EACd,IAAI,CAAC,EAAE,QAAQ,CAAC,MAAM,CAAC,EACvB,OAAO,CAAC,EAAE,gBAAgB,GACxB,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IAkB/B;;OAEG;YACW,aAAa;YAyBb,gBAAgB;IAoExB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAuB5B"}