@kurrent/kurrentdb-client 1.0.0-alpha.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 (281) hide show
  1. package/README.md +201 -0
  2. package/dist/Client/ServerFeatures.d.ts +17 -0
  3. package/dist/Client/ServerFeatures.js +56 -0
  4. package/dist/Client/ServerFeatures.js.map +1 -0
  5. package/dist/Client/discovery.d.ts +15 -0
  6. package/dist/Client/discovery.js +135 -0
  7. package/dist/Client/discovery.js.map +1 -0
  8. package/dist/Client/http.d.ts +19 -0
  9. package/dist/Client/http.js +97 -0
  10. package/dist/Client/http.js.map +1 -0
  11. package/dist/Client/index.d.ts +119 -0
  12. package/dist/Client/index.js +390 -0
  13. package/dist/Client/index.js.map +1 -0
  14. package/dist/Client/parseConnectionString.d.ts +23 -0
  15. package/dist/Client/parseConnectionString.js +238 -0
  16. package/dist/Client/parseConnectionString.js.map +1 -0
  17. package/dist/bridge/index.d.ts +66 -0
  18. package/dist/bridge/index.js +83 -0
  19. package/dist/bridge/index.js.map +1 -0
  20. package/dist/bridge/load.d.ts +1 -0
  21. package/dist/bridge/load.js +20 -0
  22. package/dist/bridge/load.js.map +1 -0
  23. package/dist/constants.d.ts +58 -0
  24. package/dist/constants.js +75 -0
  25. package/dist/constants.js.map +1 -0
  26. package/dist/events/binaryEvent.d.ts +16 -0
  27. package/dist/events/binaryEvent.js +14 -0
  28. package/dist/events/binaryEvent.js.map +1 -0
  29. package/dist/events/convertMetadata.d.ts +1 -0
  30. package/dist/events/convertMetadata.js +11 -0
  31. package/dist/events/convertMetadata.js.map +1 -0
  32. package/dist/events/index.d.ts +2 -0
  33. package/dist/events/index.js +19 -0
  34. package/dist/events/index.js.map +1 -0
  35. package/dist/events/jsonEvent.d.ts +8 -0
  36. package/dist/events/jsonEvent.js +14 -0
  37. package/dist/events/jsonEvent.js.map +1 -0
  38. package/dist/index.d.ts +13 -0
  39. package/dist/index.js +32 -0
  40. package/dist/index.js.map +1 -0
  41. package/dist/persistentSubscription/createPersistentSubscriptionToAll.d.ts +23 -0
  42. package/dist/persistentSubscription/createPersistentSubscriptionToAll.js +90 -0
  43. package/dist/persistentSubscription/createPersistentSubscriptionToAll.js.map +1 -0
  44. package/dist/persistentSubscription/createPersistentSubscriptionToStream.d.ts +17 -0
  45. package/dist/persistentSubscription/createPersistentSubscriptionToStream.js +49 -0
  46. package/dist/persistentSubscription/createPersistentSubscriptionToStream.js.map +1 -0
  47. package/dist/persistentSubscription/deletePersistentSubscriptionToAll.d.ts +13 -0
  48. package/dist/persistentSubscription/deletePersistentSubscriptionToAll.js +30 -0
  49. package/dist/persistentSubscription/deletePersistentSubscriptionToAll.js.map +1 -0
  50. package/dist/persistentSubscription/deletePersistentSubscriptionToStream.d.ts +13 -0
  51. package/dist/persistentSubscription/deletePersistentSubscriptionToStream.js +28 -0
  52. package/dist/persistentSubscription/deletePersistentSubscriptionToStream.js.map +1 -0
  53. package/dist/persistentSubscription/getPersistentSubscriptionToAllInfo.d.ts +13 -0
  54. package/dist/persistentSubscription/getPersistentSubscriptionToAllInfo.js +31 -0
  55. package/dist/persistentSubscription/getPersistentSubscriptionToAllInfo.js.map +1 -0
  56. package/dist/persistentSubscription/getPersistentSubscriptionToStreamInfo.d.ts +14 -0
  57. package/dist/persistentSubscription/getPersistentSubscriptionToStreamInfo.js +49 -0
  58. package/dist/persistentSubscription/getPersistentSubscriptionToStreamInfo.js.map +1 -0
  59. package/dist/persistentSubscription/index.d.ts +16 -0
  60. package/dist/persistentSubscription/index.js +33 -0
  61. package/dist/persistentSubscription/index.js.map +1 -0
  62. package/dist/persistentSubscription/listAllPersistentSubscriptions.d.ts +13 -0
  63. package/dist/persistentSubscription/listAllPersistentSubscriptions.js +42 -0
  64. package/dist/persistentSubscription/listAllPersistentSubscriptions.js.map +1 -0
  65. package/dist/persistentSubscription/listPersistentSubscriptionsToAll.d.ts +13 -0
  66. package/dist/persistentSubscription/listPersistentSubscriptionsToAll.js +33 -0
  67. package/dist/persistentSubscription/listPersistentSubscriptionsToAll.js.map +1 -0
  68. package/dist/persistentSubscription/listPersistentSubscriptionsToStream.d.ts +14 -0
  69. package/dist/persistentSubscription/listPersistentSubscriptionsToStream.js +51 -0
  70. package/dist/persistentSubscription/listPersistentSubscriptionsToStream.js.map +1 -0
  71. package/dist/persistentSubscription/replayParkedMessagesToAll.d.ts +18 -0
  72. package/dist/persistentSubscription/replayParkedMessagesToAll.js +36 -0
  73. package/dist/persistentSubscription/replayParkedMessagesToAll.js.map +1 -0
  74. package/dist/persistentSubscription/replayParkedMessagesToStream.d.ts +19 -0
  75. package/dist/persistentSubscription/replayParkedMessagesToStream.js +57 -0
  76. package/dist/persistentSubscription/replayParkedMessagesToStream.js.map +1 -0
  77. package/dist/persistentSubscription/restartPersistentSubscriptionSubsystem.d.ts +11 -0
  78. package/dist/persistentSubscription/restartPersistentSubscriptionSubsystem.js +30 -0
  79. package/dist/persistentSubscription/restartPersistentSubscriptionSubsystem.js.map +1 -0
  80. package/dist/persistentSubscription/subscribeToPersistentSubscriptionToAll.d.ts +20 -0
  81. package/dist/persistentSubscription/subscribeToPersistentSubscriptionToAll.js +38 -0
  82. package/dist/persistentSubscription/subscribeToPersistentSubscriptionToAll.js.map +1 -0
  83. package/dist/persistentSubscription/subscribeToPersistentSubscriptionToStream.d.ts +20 -0
  84. package/dist/persistentSubscription/subscribeToPersistentSubscriptionToStream.js +37 -0
  85. package/dist/persistentSubscription/subscribeToPersistentSubscriptionToStream.js.map +1 -0
  86. package/dist/persistentSubscription/updatePersistentSubscriptionToAll.d.ts +15 -0
  87. package/dist/persistentSubscription/updatePersistentSubscriptionToAll.js +53 -0
  88. package/dist/persistentSubscription/updatePersistentSubscriptionToAll.js.map +1 -0
  89. package/dist/persistentSubscription/updatePersistentSubscriptionToStream.d.ts +15 -0
  90. package/dist/persistentSubscription/updatePersistentSubscriptionToStream.js +49 -0
  91. package/dist/persistentSubscription/updatePersistentSubscriptionToStream.js.map +1 -0
  92. package/dist/persistentSubscription/utils/PersistentSubscriptionImpl.d.ts +18 -0
  93. package/dist/persistentSubscription/utils/PersistentSubscriptionImpl.js +112 -0
  94. package/dist/persistentSubscription/utils/PersistentSubscriptionImpl.js.map +1 -0
  95. package/dist/persistentSubscription/utils/mapPersistentSubscriptionInfo.d.ts +146 -0
  96. package/dist/persistentSubscription/utils/mapPersistentSubscriptionInfo.js +204 -0
  97. package/dist/persistentSubscription/utils/mapPersistentSubscriptionInfo.js.map +1 -0
  98. package/dist/persistentSubscription/utils/persistentSubscriptionSettings.d.ts +90 -0
  99. package/dist/persistentSubscription/utils/persistentSubscriptionSettings.js +39 -0
  100. package/dist/persistentSubscription/utils/persistentSubscriptionSettings.js.map +1 -0
  101. package/dist/persistentSubscription/utils/settingsToGRPC.d.ts +5 -0
  102. package/dist/persistentSubscription/utils/settingsToGRPC.js +49 -0
  103. package/dist/persistentSubscription/utils/settingsToGRPC.js.map +1 -0
  104. package/dist/projections/createProjection.d.ts +24 -0
  105. package/dist/projections/createProjection.js +48 -0
  106. package/dist/projections/createProjection.js.map +1 -0
  107. package/dist/projections/deleteProjection.d.ts +28 -0
  108. package/dist/projections/deleteProjection.js +33 -0
  109. package/dist/projections/deleteProjection.js.map +1 -0
  110. package/dist/projections/disableProjection.d.ts +19 -0
  111. package/dist/projections/disableProjection.js +34 -0
  112. package/dist/projections/disableProjection.js.map +1 -0
  113. package/dist/projections/enableProjection.d.ts +12 -0
  114. package/dist/projections/enableProjection.js +25 -0
  115. package/dist/projections/enableProjection.js.map +1 -0
  116. package/dist/projections/getProjectionResult.d.ts +17 -0
  117. package/dist/projections/getProjectionResult.js +29 -0
  118. package/dist/projections/getProjectionResult.js.map +1 -0
  119. package/dist/projections/getProjectionState.d.ts +17 -0
  120. package/dist/projections/getProjectionState.js +29 -0
  121. package/dist/projections/getProjectionState.js.map +1 -0
  122. package/dist/projections/getProjectionStatus.d.ts +12 -0
  123. package/dist/projections/getProjectionStatus.js +36 -0
  124. package/dist/projections/getProjectionStatus.js.map +1 -0
  125. package/dist/projections/index.d.ts +11 -0
  126. package/dist/projections/index.js +28 -0
  127. package/dist/projections/index.js.map +1 -0
  128. package/dist/projections/listProjections.d.ts +12 -0
  129. package/dist/projections/listProjections.js +36 -0
  130. package/dist/projections/listProjections.js.map +1 -0
  131. package/dist/projections/resetProjection.d.ts +13 -0
  132. package/dist/projections/resetProjection.js +25 -0
  133. package/dist/projections/resetProjection.js.map +1 -0
  134. package/dist/projections/restartSubsystem.d.ts +11 -0
  135. package/dist/projections/restartSubsystem.js +21 -0
  136. package/dist/projections/restartSubsystem.js.map +1 -0
  137. package/dist/projections/updateProjection.d.ts +20 -0
  138. package/dist/projections/updateProjection.js +34 -0
  139. package/dist/projections/updateProjection.js.map +1 -0
  140. package/dist/projections/utils/mapGrpcProjectionDetails.d.ts +3 -0
  141. package/dist/projections/utils/mapGrpcProjectionDetails.js +31 -0
  142. package/dist/projections/utils/mapGrpcProjectionDetails.js.map +1 -0
  143. package/dist/streams/appendToStream/append.d.ts +5 -0
  144. package/dist/streams/appendToStream/append.js +131 -0
  145. package/dist/streams/appendToStream/append.js.map +1 -0
  146. package/dist/streams/appendToStream/batchAppend.d.ts +5 -0
  147. package/dist/streams/appendToStream/batchAppend.js +145 -0
  148. package/dist/streams/appendToStream/batchAppend.js.map +1 -0
  149. package/dist/streams/appendToStream/index.d.ts +24 -0
  150. package/dist/streams/appendToStream/index.js +24 -0
  151. package/dist/streams/appendToStream/index.js.map +1 -0
  152. package/dist/streams/appendToStream/unpackError.d.ts +5 -0
  153. package/dist/streams/appendToStream/unpackError.js +54 -0
  154. package/dist/streams/appendToStream/unpackError.js.map +1 -0
  155. package/dist/streams/deleteStream.d.ts +18 -0
  156. package/dist/streams/deleteStream.js +51 -0
  157. package/dist/streams/deleteStream.js.map +1 -0
  158. package/dist/streams/getStreamMetadata.d.ts +27 -0
  159. package/dist/streams/getStreamMetadata.js +40 -0
  160. package/dist/streams/getStreamMetadata.js.map +1 -0
  161. package/dist/streams/index.d.ts +9 -0
  162. package/dist/streams/index.js +27 -0
  163. package/dist/streams/index.js.map +1 -0
  164. package/dist/streams/readAll.d.ts +35 -0
  165. package/dist/streams/readAll.js +37 -0
  166. package/dist/streams/readAll.js.map +1 -0
  167. package/dist/streams/readStream.d.ts +35 -0
  168. package/dist/streams/readStream.js +58 -0
  169. package/dist/streams/readStream.js.map +1 -0
  170. package/dist/streams/setStreamMetadata.d.ts +20 -0
  171. package/dist/streams/setStreamMetadata.js +20 -0
  172. package/dist/streams/setStreamMetadata.js.map +1 -0
  173. package/dist/streams/subscribeToAll.d.ts +30 -0
  174. package/dist/streams/subscribeToAll.js +89 -0
  175. package/dist/streams/subscribeToAll.js.map +1 -0
  176. package/dist/streams/subscribeToStream.d.ts +27 -0
  177. package/dist/streams/subscribeToStream.js +52 -0
  178. package/dist/streams/subscribeToStream.js.map +1 -0
  179. package/dist/streams/tombstoneStream.d.ts +18 -0
  180. package/dist/streams/tombstoneStream.js +51 -0
  181. package/dist/streams/tombstoneStream.js.map +1 -0
  182. package/dist/streams/utils/ReadStream.d.ts +14 -0
  183. package/dist/streams/utils/ReadStream.js +61 -0
  184. package/dist/streams/utils/ReadStream.js.map +1 -0
  185. package/dist/streams/utils/Subscription.d.ts +16 -0
  186. package/dist/streams/utils/Subscription.js +71 -0
  187. package/dist/streams/utils/Subscription.js.map +1 -0
  188. package/dist/streams/utils/streamMetadata.d.ts +53 -0
  189. package/dist/streams/utils/streamMetadata.js +77 -0
  190. package/dist/streams/utils/streamMetadata.js.map +1 -0
  191. package/dist/streams/utils/systemStreams.d.ts +20 -0
  192. package/dist/streams/utils/systemStreams.js +28 -0
  193. package/dist/streams/utils/systemStreams.js.map +1 -0
  194. package/dist/types/events.d.ts +157 -0
  195. package/dist/types/events.js +3 -0
  196. package/dist/types/events.js.map +1 -0
  197. package/dist/types/index.d.ts +348 -0
  198. package/dist/types/index.js +22 -0
  199. package/dist/types/index.js.map +1 -0
  200. package/dist/utils/CommandError.d.ts +174 -0
  201. package/dist/utils/CommandError.js +403 -0
  202. package/dist/utils/CommandError.js.map +1 -0
  203. package/dist/utils/backpressuredWrite.d.ts +2 -0
  204. package/dist/utils/backpressuredWrite.js +50 -0
  205. package/dist/utils/backpressuredWrite.js.map +1 -0
  206. package/dist/utils/convertBridgeError.d.ts +1 -0
  207. package/dist/utils/convertBridgeError.js +41 -0
  208. package/dist/utils/convertBridgeError.js.map +1 -0
  209. package/dist/utils/convertGrpcEvent.d.ts +10 -0
  210. package/dist/utils/convertGrpcEvent.js +135 -0
  211. package/dist/utils/convertGrpcEvent.js.map +1 -0
  212. package/dist/utils/convertRustEvent.d.ts +4 -0
  213. package/dist/utils/convertRustEvent.js +85 -0
  214. package/dist/utils/convertRustEvent.js.map +1 -0
  215. package/dist/utils/debug.d.ts +7 -0
  216. package/dist/utils/debug.js +30 -0
  217. package/dist/utils/debug.js.map +1 -0
  218. package/dist/utils/filter.d.ts +44 -0
  219. package/dist/utils/filter.js +29 -0
  220. package/dist/utils/filter.js.map +1 -0
  221. package/dist/utils/grpcStreamIdentifier.d.ts +2 -0
  222. package/dist/utils/grpcStreamIdentifier.js +11 -0
  223. package/dist/utils/grpcStreamIdentifier.js.map +1 -0
  224. package/dist/utils/grpcUUID.d.ts +4 -0
  225. package/dist/utils/grpcUUID.js +29 -0
  226. package/dist/utils/grpcUUID.js.map +1 -0
  227. package/dist/utils/index.d.ts +9 -0
  228. package/dist/utils/index.js +26 -0
  229. package/dist/utils/index.js.map +1 -0
  230. package/dist/utils/isClientCancellationError.d.ts +1 -0
  231. package/dist/utils/isClientCancellationError.js +13 -0
  232. package/dist/utils/isClientCancellationError.js.map +1 -0
  233. package/dist/utils/utilityTypes.d.ts +2 -0
  234. package/dist/utils/utilityTypes.js +3 -0
  235. package/dist/utils/utilityTypes.js.map +1 -0
  236. package/generated/cluster_grpc_pb.d.ts +211 -0
  237. package/generated/cluster_grpc_pb.js +247 -0
  238. package/generated/cluster_pb.d.ts +546 -0
  239. package/generated/cluster_pb.js +4357 -0
  240. package/generated/code_grpc_pb.js +1 -0
  241. package/generated/code_pb.d.ts +27 -0
  242. package/generated/code_pb.js +48 -0
  243. package/generated/gossip_grpc_pb.d.ts +42 -0
  244. package/generated/gossip_grpc_pb.js +45 -0
  245. package/generated/gossip_pb.d.ts +111 -0
  246. package/generated/gossip_pb.js +727 -0
  247. package/generated/monitoring_grpc_pb.d.ts +39 -0
  248. package/generated/monitoring_grpc_pb.js +44 -0
  249. package/generated/monitoring_pb.d.ts +52 -0
  250. package/generated/monitoring_pb.js +361 -0
  251. package/generated/operations_grpc_pb.d.ts +144 -0
  252. package/generated/operations_grpc_pb.js +144 -0
  253. package/generated/operations_pb.d.ts +151 -0
  254. package/generated/operations_pb.js +1050 -0
  255. package/generated/persistent_grpc_pb.d.ts +160 -0
  256. package/generated/persistent_grpc_pb.js +265 -0
  257. package/generated/persistent_pb.d.ts +1702 -0
  258. package/generated/persistent_pb.js +12340 -0
  259. package/generated/projections_grpc_pb.d.ts +194 -0
  260. package/generated/projections_grpc_pb.js +332 -0
  261. package/generated/projections_pb.d.ts +821 -0
  262. package/generated/projections_pb.js +6065 -0
  263. package/generated/serverfeatures_grpc_pb.d.ts +42 -0
  264. package/generated/serverfeatures_grpc_pb.js +45 -0
  265. package/generated/serverfeatures_pb.d.ts +61 -0
  266. package/generated/serverfeatures_pb.js +476 -0
  267. package/generated/shared_grpc_pb.js +1 -0
  268. package/generated/shared_pb.d.ts +335 -0
  269. package/generated/shared_pb.js +2374 -0
  270. package/generated/status_grpc_pb.js +1 -0
  271. package/generated/status_pb.d.ts +38 -0
  272. package/generated/status_pb.js +261 -0
  273. package/generated/streams_grpc_pb.d.ts +112 -0
  274. package/generated/streams_grpc_pb.js +180 -0
  275. package/generated/streams_pb.d.ts +1660 -0
  276. package/generated/streams_pb.js +11556 -0
  277. package/generated/users_grpc_pb.d.ts +158 -0
  278. package/generated/users_grpc_pb.js +275 -0
  279. package/generated/users_pb.d.ts +601 -0
  280. package/generated/users_pb.js +4451 -0
  281. package/package.json +65 -0
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const projections_grpc_pb_1 = require("../../generated/projections_grpc_pb");
4
+ const shared_pb_1 = require("../../generated/shared_pb");
5
+ const Client_1 = require("../Client");
6
+ const utils_1 = require("../utils");
7
+ Client_1.Client.prototype.restartSubsystem = async function (baseOptions = {}) {
8
+ const req = new shared_pb_1.Empty();
9
+ utils_1.debug.command("restartSubsystem: %O", {
10
+ options: baseOptions,
11
+ });
12
+ utils_1.debug.command_grpc("restartSubsystem: %g", req);
13
+ return this.execute(projections_grpc_pb_1.ProjectionsClient, "restartSubsystem", (client) => new Promise((resolve, reject) => {
14
+ client.restartSubsystem(req, ...this.callArguments(baseOptions), (error) => {
15
+ if (error)
16
+ return reject((0, utils_1.convertToCommandError)(error));
17
+ return resolve();
18
+ });
19
+ }));
20
+ };
21
+ //# sourceMappingURL=restartSubsystem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"restartSubsystem.js","sourceRoot":"","sources":["../../src/projections/restartSubsystem.ts"],"names":[],"mappings":";;AAAA,6EAAwE;AACxE,yDAAkD;AAElD,sCAAmC;AAEnC,oCAAwD;AAcxD,eAAM,CAAC,SAAS,CAAC,gBAAgB,GAAG,KAAK,WAEvC,cAAuC,EAAE;IAEzC,MAAM,GAAG,GAAG,IAAI,iBAAK,EAAE,CAAC;IAExB,aAAK,CAAC,OAAO,CAAC,sBAAsB,EAAE;QACpC,OAAO,EAAE,WAAW;KACrB,CAAC,CAAC;IACH,aAAK,CAAC,YAAY,CAAC,sBAAsB,EAAE,GAAG,CAAC,CAAC;IAEhD,OAAO,IAAI,CAAC,OAAO,CACjB,uCAAiB,EACjB,kBAAkB,EAClB,CAAC,MAAM,EAAE,EAAE,CACT,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACpC,MAAM,CAAC,gBAAgB,CACrB,GAAG,EACH,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,EAClC,CAAC,KAAK,EAAE,EAAE;YACR,IAAI,KAAK;gBAAE,OAAO,MAAM,CAAC,IAAA,6BAAqB,EAAC,KAAK,CAAC,CAAC,CAAC;YACvD,OAAO,OAAO,EAAE,CAAC;QACnB,CAAC,CACF,CAAC;IACJ,CAAC,CAAC,CACL,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,20 @@
1
+ import type { BaseOptions } from "../types";
2
+ export interface UpdateProjectionOptions extends BaseOptions {
3
+ /**
4
+ * Enables emitting events from the projection.
5
+ * Passing `undefined` will leave emitEnabled at its current value.
6
+ * @defaultValue undefined
7
+ */
8
+ emitEnabled?: boolean;
9
+ }
10
+ declare module "../Client" {
11
+ interface Client {
12
+ /**
13
+ * Updates a projection.
14
+ * @param projectionName - The name of the projection.
15
+ * @param query - The query to run.
16
+ * @param options - Projection options.
17
+ */
18
+ updateProjection(projectionName: string, query: string, options?: UpdateProjectionOptions): Promise<void>;
19
+ }
20
+ }
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const projections_grpc_pb_1 = require("../../generated/projections_grpc_pb");
4
+ const projections_pb_1 = require("../../generated/projections_pb");
5
+ const shared_pb_1 = require("../../generated/shared_pb");
6
+ const Client_1 = require("../Client");
7
+ const utils_1 = require("../utils");
8
+ Client_1.Client.prototype.updateProjection = async function (projectionName, query, { emitEnabled, ...baseOptions } = {}) {
9
+ const req = new projections_pb_1.UpdateReq();
10
+ const options = new projections_pb_1.UpdateReq.Options();
11
+ options.setName(projectionName);
12
+ options.setQuery(query);
13
+ if (emitEnabled == null) {
14
+ options.setNoEmitOptions(new shared_pb_1.Empty());
15
+ }
16
+ else {
17
+ options.setEmitEnabled(emitEnabled);
18
+ }
19
+ req.setOptions(options);
20
+ utils_1.debug.command("updateProjection: %O", {
21
+ projectionName,
22
+ query,
23
+ options: { emitEnabled, ...baseOptions },
24
+ });
25
+ utils_1.debug.command_grpc("updateProjection: %g", req);
26
+ return this.execute(projections_grpc_pb_1.ProjectionsClient, "updateProjection", (client) => new Promise((resolve, reject) => {
27
+ client.update(req, ...this.callArguments(baseOptions), (error) => {
28
+ if (error)
29
+ return reject((0, utils_1.convertToCommandError)(error));
30
+ return resolve();
31
+ });
32
+ }));
33
+ };
34
+ //# sourceMappingURL=updateProjection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"updateProjection.js","sourceRoot":"","sources":["../../src/projections/updateProjection.ts"],"names":[],"mappings":";;AAAA,6EAAwE;AACxE,mEAA2D;AAC3D,yDAAkD;AAElD,sCAAmC;AAEnC,oCAAwD;AA2BxD,eAAM,CAAC,SAAS,CAAC,gBAAgB,GAAG,KAAK,WAEvC,cAAsB,EACtB,KAAa,EACb,EAAE,WAAW,EAAE,GAAG,WAAW,KAA8B,EAAE;IAE7D,MAAM,GAAG,GAAG,IAAI,0BAAS,EAAE,CAAC;IAC5B,MAAM,OAAO,GAAG,IAAI,0BAAS,CAAC,OAAO,EAAE,CAAC;IAExC,OAAO,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;IAChC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAExB,IAAI,WAAW,IAAI,IAAI,EAAE,CAAC;QACxB,OAAO,CAAC,gBAAgB,CAAC,IAAI,iBAAK,EAAE,CAAC,CAAC;IACxC,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;IACtC,CAAC;IAED,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IAExB,aAAK,CAAC,OAAO,CAAC,sBAAsB,EAAE;QACpC,cAAc;QACd,KAAK;QACL,OAAO,EAAE,EAAE,WAAW,EAAE,GAAG,WAAW,EAAE;KACzC,CAAC,CAAC;IACH,aAAK,CAAC,YAAY,CAAC,sBAAsB,EAAE,GAAG,CAAC,CAAC;IAEhD,OAAO,IAAI,CAAC,OAAO,CACjB,uCAAiB,EACjB,kBAAkB,EAClB,CAAC,MAAM,EAAE,EAAE,CACT,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACpC,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE;YAC/D,IAAI,KAAK;gBAAE,OAAO,MAAM,CAAC,IAAA,6BAAqB,EAAC,KAAK,CAAC,CAAC,CAAC;YACvD,OAAO,OAAO,EAAE,CAAC;QACnB,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CACL,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { StatisticsResp } from "../../../generated/projections_pb";
2
+ import type { ProjectionDetails } from "../../types";
3
+ export declare const mapGrpcProjectionDetails: (grpcProjectionDetails: StatisticsResp.Details) => ProjectionDetails;
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.mapGrpcProjectionDetails = void 0;
4
+ const mapGrpcProjectionDetails = (grpcProjectionDetails) => {
5
+ const details = grpcProjectionDetails.toObject();
6
+ const [projectionStatus, processingStatus = ""] = details.status.split("/");
7
+ return {
8
+ coreProcessingTime: BigInt(details.coreprocessingtime),
9
+ version: BigInt(details.version),
10
+ epoch: BigInt(details.epoch),
11
+ effectiveName: details.effectivename,
12
+ writesInProgress: details.writesinprogress,
13
+ readsInProgress: details.readsinprogress,
14
+ partitionsCached: details.partitionscached,
15
+ status: details.status,
16
+ projectionStatus: projectionStatus,
17
+ processingStatus: processingStatus,
18
+ stateReason: details.statereason,
19
+ name: details.name,
20
+ position: details.position,
21
+ progress: details.progress,
22
+ lastCheckpoint: details.lastcheckpoint,
23
+ eventsProcessedAfterRestart: BigInt(details.eventsprocessedafterrestart),
24
+ checkpointStatus: details.checkpointstatus,
25
+ bufferedEvents: BigInt(details.bufferedevents),
26
+ writePendingEventsBeforeCheckpoint: details.writependingeventsbeforecheckpoint,
27
+ writePendingEventsAfterCheckpoint: details.writependingeventsaftercheckpoint,
28
+ };
29
+ };
30
+ exports.mapGrpcProjectionDetails = mapGrpcProjectionDetails;
31
+ //# sourceMappingURL=mapGrpcProjectionDetails.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mapGrpcProjectionDetails.js","sourceRoot":"","sources":["../../../src/projections/utils/mapGrpcProjectionDetails.ts"],"names":[],"mappings":";;;AAQO,MAAM,wBAAwB,GAAG,CACtC,qBAA6C,EAC1B,EAAE;IACrB,MAAM,OAAO,GAAG,qBAAqB,CAAC,QAAQ,EAAE,CAAC;IACjD,MAAM,CAAC,gBAAgB,EAAE,gBAAgB,GAAG,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAE5E,OAAO;QACL,kBAAkB,EAAE,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC;QACtD,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC;QAChC,KAAK,EAAE,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC;QAC5B,aAAa,EAAE,OAAO,CAAC,aAAa;QACpC,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;QAC1C,eAAe,EAAE,OAAO,CAAC,eAAe;QACxC,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;QAC1C,MAAM,EAAE,OAAO,CAAC,MAAM;QACtB,gBAAgB,EAAE,gBAAoC;QACtD,gBAAgB,EAAE,gBAAoC;QACtD,WAAW,EAAE,OAAO,CAAC,WAAW;QAChC,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,QAAQ,EAAE,OAAO,CAAC,QAAQ;QAC1B,QAAQ,EAAE,OAAO,CAAC,QAAQ;QAC1B,cAAc,EAAE,OAAO,CAAC,cAAc;QACtC,2BAA2B,EAAE,MAAM,CAAC,OAAO,CAAC,2BAA2B,CAAC;QACxE,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;QAC1C,cAAc,EAAE,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC;QAC9C,kCAAkC,EAChC,OAAO,CAAC,kCAAkC;QAC5C,iCAAiC,EAC/B,OAAO,CAAC,iCAAiC;KAC5C,CAAC;AACJ,CAAC,CAAC;AA9BW,QAAA,wBAAwB,4BA8BnC"}
@@ -0,0 +1,5 @@
1
+ import type { Client } from "../../Client";
2
+ import type { AppendResult, EventData } from "../../types";
3
+ import { InternalOptions } from "../../utils";
4
+ import type { AppendToStreamOptions } from ".";
5
+ export declare const append: (this: Client, streamName: string, events: EventData[], { expectedRevision, ...baseOptions }: InternalOptions<AppendToStreamOptions>) => Promise<AppendResult>;
@@ -0,0 +1,131 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.append = void 0;
4
+ const streams_pb_1 = require("../../../generated/streams_pb");
5
+ const shared_pb_1 = require("../../../generated/shared_pb");
6
+ const streams_grpc_pb_1 = require("../../../generated/streams_grpc_pb");
7
+ const utils_1 = require("../../utils");
8
+ const append = async function (streamName, events, { expectedRevision, ...baseOptions }) {
9
+ const header = new streams_pb_1.AppendReq();
10
+ const options = new streams_pb_1.AppendReq.Options();
11
+ const identifier = (0, utils_1.createStreamIdentifier)(streamName);
12
+ options.setStreamIdentifier(identifier);
13
+ switch (expectedRevision) {
14
+ case "any": {
15
+ options.setAny(new shared_pb_1.Empty());
16
+ break;
17
+ }
18
+ case "no_stream": {
19
+ options.setNoStream(new shared_pb_1.Empty());
20
+ break;
21
+ }
22
+ case "stream_exists": {
23
+ options.setStreamExists(new shared_pb_1.Empty());
24
+ break;
25
+ }
26
+ default: {
27
+ options.setRevision(expectedRevision.toString(10));
28
+ break;
29
+ }
30
+ }
31
+ header.setOptions(options);
32
+ utils_1.debug.command("appendToStream: %O", {
33
+ streamName,
34
+ events,
35
+ options: { expectedRevision, ...baseOptions },
36
+ });
37
+ utils_1.debug.command_grpc("appendToStream: %g", header);
38
+ return this.execute(streams_grpc_pb_1.StreamsClient, "appendToStream", (client) => new Promise(async (resolve, reject) => {
39
+ const sink = client.append(...this.callArguments(baseOptions), (error, resp) => {
40
+ if (error != null) {
41
+ return reject((0, utils_1.convertToCommandError)(error));
42
+ }
43
+ if (resp.hasWrongExpectedVersion()) {
44
+ const grpcError = resp.getWrongExpectedVersion();
45
+ let expected = "any";
46
+ switch (true) {
47
+ case grpcError.hasExpectedRevision(): {
48
+ expected = BigInt(grpcError.getExpectedRevision());
49
+ break;
50
+ }
51
+ case grpcError.hasExpectedStreamExists(): {
52
+ expected = "stream_exists";
53
+ break;
54
+ }
55
+ case grpcError.hasExpectedNoStream(): {
56
+ expected = "no_stream";
57
+ break;
58
+ }
59
+ }
60
+ if (this.throwOnAppendFailure) {
61
+ return reject(new utils_1.WrongExpectedVersionError(null, {
62
+ streamName: streamName,
63
+ current: grpcError.hasCurrentRevision()
64
+ ? BigInt(grpcError.getCurrentRevision())
65
+ : "no_stream",
66
+ expected,
67
+ }));
68
+ }
69
+ const nextExpectedRevision = grpcError.hasCurrentRevision()
70
+ ? BigInt(grpcError.getCurrentRevision())
71
+ : BigInt(-1);
72
+ return resolve({
73
+ success: false,
74
+ nextExpectedRevision,
75
+ position: undefined,
76
+ });
77
+ }
78
+ if (resp.hasSuccess()) {
79
+ const success = resp.getSuccess();
80
+ const nextExpectedRevision = BigInt(success.getCurrentRevision());
81
+ const grpcPosition = success.getPosition();
82
+ const position = grpcPosition
83
+ ? {
84
+ commit: BigInt(grpcPosition.getCommitPosition()),
85
+ prepare: BigInt(grpcPosition.getPreparePosition()),
86
+ }
87
+ : undefined;
88
+ return resolve({
89
+ success: true,
90
+ nextExpectedRevision,
91
+ position,
92
+ });
93
+ }
94
+ });
95
+ sink.on("error", (err) => reject(err));
96
+ await (0, utils_1.backpressuredWrite)(sink, header);
97
+ for (const event of events) {
98
+ const entry = new streams_pb_1.AppendReq();
99
+ const message = new streams_pb_1.AppendReq.ProposedMessage();
100
+ const id = (0, utils_1.createUUID)(event.id);
101
+ message.setId(id);
102
+ message.getMetadataMap().set("type", event.type);
103
+ message.getMetadataMap().set("content-type", event.contentType);
104
+ switch (event.contentType) {
105
+ case "application/json": {
106
+ const data = JSON.stringify(event.data);
107
+ message.setData(Buffer.from(data, "utf8").toString("base64"));
108
+ break;
109
+ }
110
+ case "application/octet-stream": {
111
+ message.setData(event.data);
112
+ break;
113
+ }
114
+ }
115
+ if (event.metadata) {
116
+ if (event.metadata.constructor === Uint8Array) {
117
+ message.setCustomMetadata(event.metadata);
118
+ }
119
+ else {
120
+ const metadata = JSON.stringify(event.metadata);
121
+ message.setCustomMetadata(Buffer.from(metadata, "utf8").toString("base64"));
122
+ }
123
+ }
124
+ entry.setProposedMessage(message);
125
+ await (0, utils_1.backpressuredWrite)(sink, entry);
126
+ }
127
+ sink.end();
128
+ }));
129
+ };
130
+ exports.append = append;
131
+ //# sourceMappingURL=append.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"append.js","sourceRoot":"","sources":["../../../src/streams/appendToStream/append.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import type { Client } from "../../Client";
2
+ import type { AppendResult, EventData } from "../../types";
3
+ import { InternalOptions } from "../../utils";
4
+ import type { AppendToStreamOptions } from ".";
5
+ export declare const batchAppend: (this: Client, streamName: string, events: EventData[], { expectedRevision, batchAppendSize, ...baseOptions }: InternalOptions<AppendToStreamOptions>) => Promise<AppendResult>;
@@ -0,0 +1,145 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.batchAppend = void 0;
4
+ const uuid_1 = require("uuid");
5
+ const timestamp_pb_1 = require("google-protobuf/google/protobuf/timestamp_pb");
6
+ const streams_grpc_pb_1 = require("../../../generated/streams_grpc_pb");
7
+ const streams_pb_1 = require("../../../generated/streams_pb");
8
+ const shared_pb_1 = require("../../../generated/shared_pb");
9
+ const utils_1 = require("../../utils");
10
+ const unpackError_1 = require("./unpackError");
11
+ const streamCache = new WeakMap();
12
+ const promiseBank = new Map();
13
+ const batchAppend = async function (streamName, events, { expectedRevision, batchAppendSize, ...baseOptions }) {
14
+ const correlationId = (0, uuid_1.v4)();
15
+ const stream = await this.GRPCStreamCreator(streams_grpc_pb_1.StreamsClient, "appendToStream", (client) => client
16
+ .batchAppend(...this.callArguments(baseOptions, {
17
+ deadline: Infinity,
18
+ }))
19
+ .on("data", (resp) => {
20
+ const resultingId = (0, utils_1.parseUUID)(resp.getCorrelationId());
21
+ const [resolve, reject] = promiseBank.get(resultingId);
22
+ promiseBank.delete(resultingId);
23
+ if (resp.hasError()) {
24
+ const grpcError = resp.getError();
25
+ if (!this.throwOnAppendFailure) {
26
+ const wrongExpectedVersion = (0, unpackError_1.unpackWrongExpectedVersion)(grpcError);
27
+ if (wrongExpectedVersion) {
28
+ const nextExpectedRevision = wrongExpectedVersion.hasCurrentStreamRevision()
29
+ ? BigInt(wrongExpectedVersion.hasCurrentStreamRevision())
30
+ : BigInt(-1);
31
+ return resolve({
32
+ success: false,
33
+ nextExpectedRevision,
34
+ position: undefined,
35
+ });
36
+ }
37
+ }
38
+ return reject((0, unpackError_1.unpackToCommandError)(grpcError, Buffer.from(resp.getStreamIdentifier().getStreamName()).toString("utf8")));
39
+ }
40
+ const success = resp.getSuccess();
41
+ const nextExpectedRevision = BigInt(success.getCurrentRevision());
42
+ const grpcPosition = success.getPosition();
43
+ const position = grpcPosition
44
+ ? {
45
+ commit: BigInt(grpcPosition.getCommitPosition()),
46
+ prepare: BigInt(grpcPosition.getPreparePosition()),
47
+ }
48
+ : undefined;
49
+ return resolve({
50
+ success: true,
51
+ nextExpectedRevision,
52
+ position,
53
+ });
54
+ })
55
+ .on("error", (error) => {
56
+ for (const [_, reject] of promiseBank.values()) {
57
+ reject((0, utils_1.convertToCommandError)(error));
58
+ }
59
+ promiseBank.clear();
60
+ }), streamCache)();
61
+ return new Promise(async (...batchPromise) => {
62
+ promiseBank.set(correlationId, batchPromise);
63
+ const correlationUUID = (0, utils_1.createUUID)(correlationId);
64
+ const options = new streams_pb_1.BatchAppendReq.Options();
65
+ const identifier = (0, utils_1.createStreamIdentifier)(streamName);
66
+ const deadline = timestamp_pb_1.Timestamp.fromDate(this.createDeadline(baseOptions.deadline));
67
+ options.setStreamIdentifier(identifier);
68
+ options.setDeadline(deadline);
69
+ switch (expectedRevision) {
70
+ case "any": {
71
+ options.setAny(new shared_pb_1.Empty());
72
+ break;
73
+ }
74
+ case "no_stream": {
75
+ options.setNoStream(new shared_pb_1.Empty());
76
+ break;
77
+ }
78
+ case "stream_exists": {
79
+ options.setStreamExists(new shared_pb_1.Empty());
80
+ break;
81
+ }
82
+ default: {
83
+ options.setStreamPosition(expectedRevision.toString(10));
84
+ break;
85
+ }
86
+ }
87
+ for (const batch of eventBatcher(events, correlationUUID, options, batchAppendSize)) {
88
+ utils_1.debug.command_grpc("batchAppend: %g", batch);
89
+ await (0, utils_1.backpressuredWrite)(stream, batch);
90
+ }
91
+ });
92
+ };
93
+ exports.batchAppend = batchAppend;
94
+ function* eventBatcher(events, correlationId, options, maxBatchSize) {
95
+ const createAppendRequest = (addOptions = false) => {
96
+ const appendRequest = new streams_pb_1.BatchAppendReq();
97
+ if (addOptions) {
98
+ appendRequest.setOptions(options);
99
+ }
100
+ appendRequest.setCorrelationId(correlationId);
101
+ appendRequest.setIsFinal(false);
102
+ return appendRequest;
103
+ };
104
+ let appendRequest = createAppendRequest(true);
105
+ let batchSize = 0;
106
+ for (const event of events) {
107
+ const message = new streams_pb_1.BatchAppendReq.ProposedMessage();
108
+ const id = new shared_pb_1.UUID();
109
+ id.setString(event.id);
110
+ message.setId(id);
111
+ message.getMetadataMap().set("type", event.type);
112
+ message.getMetadataMap().set("content-type", event.contentType);
113
+ switch (event.contentType) {
114
+ case "application/json": {
115
+ const data = JSON.stringify(event.data);
116
+ message.setData(Buffer.from(data, "utf8").toString("base64"));
117
+ break;
118
+ }
119
+ case "application/octet-stream": {
120
+ message.setData(event.data);
121
+ break;
122
+ }
123
+ }
124
+ if (event.metadata) {
125
+ if (event.metadata.constructor === Uint8Array) {
126
+ message.setCustomMetadata(event.metadata);
127
+ }
128
+ else {
129
+ const metadata = JSON.stringify(event.metadata);
130
+ message.setCustomMetadata(Buffer.from(metadata, "utf8").toString("base64"));
131
+ }
132
+ }
133
+ const messageSize = message.serializeBinary().length;
134
+ if (batchSize + messageSize >= maxBatchSize) {
135
+ yield appendRequest;
136
+ appendRequest = createAppendRequest(false);
137
+ batchSize = 0;
138
+ }
139
+ batchSize += messageSize;
140
+ appendRequest.addProposedMessages(message);
141
+ }
142
+ appendRequest.setIsFinal(true);
143
+ yield appendRequest;
144
+ }
145
+ //# sourceMappingURL=batchAppend.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"batchAppend.js","sourceRoot":"","sources":["../../../src/streams/appendToStream/batchAppend.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import type { BaseOptions, AppendResult, AppendExpectedRevision, EventData, EventType } from "../../types";
2
+ export interface AppendToStreamOptions extends BaseOptions {
3
+ /**
4
+ * Asks the server to check the stream is at specific revision before writing events.
5
+ * @defaultValue ANY
6
+ */
7
+ expectedRevision?: AppendExpectedRevision;
8
+ /**
9
+ * The batch size, in bytes.
10
+ * @defaultValue 3 * 1024 * 1024
11
+ */
12
+ batchAppendSize?: number;
13
+ }
14
+ declare module "../../Client" {
15
+ interface Client {
16
+ /**
17
+ * Appends events to a given stream.
18
+ * @param streamName - A stream name.
19
+ * @param events - Events or event to write.
20
+ * @param options - Writing options.
21
+ */
22
+ appendToStream<KnownEventType extends EventType = EventType>(streamName: string, events: EventData<KnownEventType> | EventData<KnownEventType>[], options?: AppendToStreamOptions): Promise<AppendResult>;
23
+ }
24
+ }
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const streams_grpc_pb_1 = require("../../../generated/streams_grpc_pb");
4
+ const Client_1 = require("../../Client");
5
+ const constants_1 = require("../../constants");
6
+ const append_1 = require("./append");
7
+ const batchAppend_1 = require("./batchAppend");
8
+ Client_1.Client.prototype.appendToStream = async function (streamName, event, { expectedRevision = constants_1.ANY, batchAppendSize = 3 * 1024 * 1024, ...baseOptions } = {}) {
9
+ const events = Array.isArray(event) ? event : [event];
10
+ if (!baseOptions.credentials &&
11
+ (await this.supports(streams_grpc_pb_1.StreamsService.batchAppend))) {
12
+ return batchAppend_1.batchAppend.call(this, streamName, events, {
13
+ expectedRevision,
14
+ batchAppendSize,
15
+ ...baseOptions,
16
+ });
17
+ }
18
+ return append_1.append.call(this, streamName, events, {
19
+ expectedRevision,
20
+ batchAppendSize,
21
+ ...baseOptions,
22
+ });
23
+ };
24
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/streams/appendToStream/index.ts"],"names":[],"mappings":";;AAAA,wEAAoE;AAEpE,yCAAsC;AACtC,+CAAsC;AAStC,qCAAkC;AAClC,+CAA4C;AA+B5C,eAAM,CAAC,SAAS,CAAC,cAAc,GAAG,KAAK,WAIrC,UAAkB,EAClB,KAA8D,EAC9D,EACE,gBAAgB,GAAG,eAAG,EACtB,eAAe,GAAG,CAAC,GAAG,IAAI,GAAG,IAAI,EACjC,GAAG,WAAW,KACW,EAAE;IAE7B,MAAM,MAAM,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IAEtD,IACE,CAAC,WAAW,CAAC,WAAW;QACxB,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,gCAAc,CAAC,WAAW,CAAC,CAAC,EACjD,CAAC;QACD,OAAO,yBAAW,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE;YAChD,gBAAgB;YAChB,eAAe;YACf,GAAG,WAAW;SACf,CAAC,CAAC;IACL,CAAC;IAED,OAAO,eAAM,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE;QAC3C,gBAAgB;QAChB,eAAe;QACf,GAAG,WAAW;KACf,CAAC,CAAC;AACL,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { Status } from "../../../generated/status_pb";
2
+ import { WrongExpectedVersion } from "../../../generated/shared_pb";
3
+ import { AccessDeniedError, MaxAppendSizeExceededError, StreamDeletedError, DeadlineExceededError, UnknownError, WrongExpectedVersionError } from "../../utils/CommandError";
4
+ export declare const unpackWrongExpectedVersion: (grpcError: Status) => WrongExpectedVersion | null;
5
+ export declare const unpackToCommandError: (grpcError: Status, streamName: string) => DeadlineExceededError | UnknownError | AccessDeniedError | StreamDeletedError | WrongExpectedVersionError | MaxAppendSizeExceededError;
@@ -0,0 +1,54 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.unpackToCommandError = exports.unpackWrongExpectedVersion = void 0;
4
+ const shared_pb_1 = require("../../../generated/shared_pb");
5
+ const CommandError_1 = require("../../utils/CommandError");
6
+ const unpackWrongExpectedVersion = (grpcError) => grpcError
7
+ .getDetails()
8
+ ?.unpack(shared_pb_1.WrongExpectedVersion.deserializeBinary, "event_store.client.WrongExpectedVersion") ?? null;
9
+ exports.unpackWrongExpectedVersion = unpackWrongExpectedVersion;
10
+ const unpackToCommandError = (grpcError, streamName) => {
11
+ const details = grpcError.getDetails();
12
+ const typename = details.getTypeName();
13
+ switch (typename) {
14
+ case "event_store.client.WrongExpectedVersion": {
15
+ const unpacked = details.unpack(shared_pb_1.WrongExpectedVersion.deserializeBinary, typename);
16
+ if (!unpacked)
17
+ break;
18
+ return CommandError_1.WrongExpectedVersionError.fromWrongExpectedVersion(unpacked, streamName);
19
+ }
20
+ case "event_store.client.StreamDeleted": {
21
+ const unpacked = details.unpack(shared_pb_1.StreamDeleted.deserializeBinary, typename);
22
+ if (!unpacked)
23
+ break;
24
+ return CommandError_1.StreamDeletedError.fromStreamName(streamName);
25
+ }
26
+ case "event_store.client.AccessDenied": {
27
+ const unpacked = details.unpack(shared_pb_1.AccessDenied.deserializeBinary, typename);
28
+ if (!unpacked)
29
+ break;
30
+ return new CommandError_1.AccessDeniedError();
31
+ }
32
+ case "event_store.client.Timeout": {
33
+ const unpacked = details.unpack(shared_pb_1.Timeout.deserializeBinary, typename);
34
+ if (!unpacked)
35
+ break;
36
+ return new CommandError_1.DeadlineExceededError();
37
+ }
38
+ case "event_store.client.Unknown": {
39
+ const unpacked = details.unpack(shared_pb_1.Unknown.deserializeBinary, typename);
40
+ if (!unpacked)
41
+ break;
42
+ return new CommandError_1.UnknownError();
43
+ }
44
+ case "event_store.client.MaximumAppendSizeExceeded": {
45
+ const unpacked = details.unpack(shared_pb_1.MaximumAppendSizeExceeded.deserializeBinary, typename);
46
+ if (!unpacked)
47
+ break;
48
+ return CommandError_1.MaxAppendSizeExceededError.fromMaxAppendSize(unpacked.getMaxappendsize());
49
+ }
50
+ }
51
+ return new CommandError_1.UnknownError(undefined, `Could not recognize ${grpcError.getMessage()}`);
52
+ };
53
+ exports.unpackToCommandError = unpackToCommandError;
54
+ //# sourceMappingURL=unpackError.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unpackError.js","sourceRoot":"","sources":["../../../src/streams/appendToStream/unpackError.ts"],"names":[],"mappings":";;;AACA,4DAOsC;AAEtC,2DAOkC;AAE3B,MAAM,0BAA0B,GAAG,CAAC,SAAiB,EAAE,EAAE,CAC9D,SAAS;KACN,UAAU,EAAE;IACb,EAAE,MAAM,CACN,gCAAoB,CAAC,iBAAiB,EACtC,yCAAyC,CAC1C,IAAI,IAAI,CAAC;AAND,QAAA,0BAA0B,8BAMzB;AAEP,MAAM,oBAAoB,GAAG,CAAC,SAAiB,EAAE,UAAkB,EAAE,EAAE;IAC5E,MAAM,OAAO,GAAG,SAAS,CAAC,UAAU,EAAG,CAAC;IACxC,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;IAEvC,QAAQ,QAAQ,EAAE,CAAC;QACjB,KAAK,yCAAyC,CAAC,CAAC,CAAC;YAC/C,MAAM,QAAQ,GAAG,OAAO,CAAC,MAAM,CAC7B,gCAAoB,CAAC,iBAAiB,EACtC,QAAQ,CACT,CAAC;YACF,IAAI,CAAC,QAAQ;gBAAE,MAAM;YACrB,OAAO,wCAAyB,CAAC,wBAAwB,CACvD,QAAQ,EACR,UAAU,CACX,CAAC;QACJ,CAAC;QACD,KAAK,kCAAkC,CAAC,CAAC,CAAC;YACxC,MAAM,QAAQ,GAAG,OAAO,CAAC,MAAM,CAC7B,yBAAa,CAAC,iBAAiB,EAC/B,QAAQ,CACT,CAAC;YACF,IAAI,CAAC,QAAQ;gBAAE,MAAM;YACrB,OAAO,iCAAkB,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;QACvD,CAAC;QACD,KAAK,iCAAiC,CAAC,CAAC,CAAC;YACvC,MAAM,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC,wBAAY,CAAC,iBAAiB,EAAE,QAAQ,CAAC,CAAC;YAC1E,IAAI,CAAC,QAAQ;gBAAE,MAAM;YACrB,OAAO,IAAI,gCAAiB,EAAE,CAAC;QACjC,CAAC;QACD,KAAK,4BAA4B,CAAC,CAAC,CAAC;YAClC,MAAM,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC,mBAAO,CAAC,iBAAiB,EAAE,QAAQ,CAAC,CAAC;YACrE,IAAI,CAAC,QAAQ;gBAAE,MAAM;YACrB,OAAO,IAAI,oCAAqB,EAAE,CAAC;QACrC,CAAC;QACD,KAAK,4BAA4B,CAAC,CAAC,CAAC;YAClC,MAAM,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC,mBAAO,CAAC,iBAAiB,EAAE,QAAQ,CAAC,CAAC;YACrE,IAAI,CAAC,QAAQ;gBAAE,MAAM;YACrB,OAAO,IAAI,2BAAY,EAAE,CAAC;QAC5B,CAAC;QACD,KAAK,8CAA8C,CAAC,CAAC,CAAC;YACpD,MAAM,QAAQ,GAAG,OAAO,CAAC,MAAM,CAC7B,qCAAyB,CAAC,iBAAiB,EAC3C,QAAQ,CACT,CAAC;YACF,IAAI,CAAC,QAAQ;gBAAE,MAAM;YACrB,OAAO,yCAA0B,CAAC,iBAAiB,CACjD,QAAQ,CAAC,gBAAgB,EAAE,CAC5B,CAAC;QACJ,CAAC;IACH,CAAC;IACD,OAAO,IAAI,2BAAY,CACrB,SAAS,EACT,uBAAuB,SAAS,CAAC,UAAU,EAAE,EAAE,CAChD,CAAC;AACJ,CAAC,CAAC;AAtDW,QAAA,oBAAoB,wBAsD/B"}
@@ -0,0 +1,18 @@
1
+ import type { BaseOptions, DeleteResult, ExpectedRevision } from "../types";
2
+ export interface DeleteStreamOptions extends BaseOptions {
3
+ /**
4
+ * Asks the server to check the stream is at specific revision before deleting.
5
+ * @defaultValue ANY
6
+ */
7
+ expectedRevision?: ExpectedRevision;
8
+ }
9
+ declare module "../Client" {
10
+ interface Client {
11
+ /**
12
+ * Soft-deletes a stream.
13
+ * @param streamName - A stream name.
14
+ * @param options - Deletion options.
15
+ */
16
+ deleteStream(streamName: string, options?: DeleteStreamOptions): Promise<DeleteResult>;
17
+ }
18
+ }
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const streams_pb_1 = require("../../generated/streams_pb");
4
+ const shared_pb_1 = require("../../generated/shared_pb");
5
+ const streams_grpc_pb_1 = require("../../generated/streams_grpc_pb");
6
+ const Client_1 = require("../Client");
7
+ const utils_1 = require("../utils");
8
+ const constants_1 = require("../constants");
9
+ Client_1.Client.prototype.deleteStream = async function (streamName, { expectedRevision = constants_1.ANY, ...baseOptions } = {}) {
10
+ const req = new streams_pb_1.DeleteReq();
11
+ const options = new streams_pb_1.DeleteReq.Options();
12
+ const identifier = (0, utils_1.createStreamIdentifier)(streamName);
13
+ options.setStreamIdentifier(identifier);
14
+ switch (expectedRevision) {
15
+ case constants_1.ANY: {
16
+ options.setAny(new shared_pb_1.Empty());
17
+ break;
18
+ }
19
+ case constants_1.NO_STREAM: {
20
+ options.setNoStream(new shared_pb_1.Empty());
21
+ break;
22
+ }
23
+ default: {
24
+ options.setRevision(expectedRevision.toString(10));
25
+ break;
26
+ }
27
+ }
28
+ req.setOptions(options);
29
+ utils_1.debug.command("deleteStream: %O", {
30
+ streamName,
31
+ options: { expectedRevision, ...baseOptions },
32
+ });
33
+ utils_1.debug.command_grpc("deleteStream: %g", req);
34
+ return this.execute(streams_grpc_pb_1.StreamsClient, "deleteStream", (client) => new Promise((resolve, reject) => {
35
+ client.delete(req, ...this.callArguments(baseOptions), (error, resp) => {
36
+ if (error) {
37
+ return reject((0, utils_1.convertToCommandError)(error));
38
+ }
39
+ const result = {};
40
+ if (resp.hasPosition()) {
41
+ const grpcPos = resp.getPosition();
42
+ result.position = {
43
+ commit: BigInt(grpcPos.getCommitPosition()),
44
+ prepare: BigInt(grpcPos.getPreparePosition()),
45
+ };
46
+ }
47
+ return resolve(result);
48
+ });
49
+ }));
50
+ };
51
+ //# sourceMappingURL=deleteStream.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deleteStream.js","sourceRoot":"","sources":["../../src/streams/deleteStream.ts"],"names":[],"mappings":";;AAAA,2DAAuD;AACvD,yDAAkD;AAClD,qEAAgE;AAEhE,sCAAmC;AAEnC,oCAAgF;AAChF,4CAA8C;AAwB9C,eAAM,CAAC,SAAS,CAAC,YAAY,GAAG,KAAK,WAEnC,UAAkB,EAClB,EAAE,gBAAgB,GAAG,eAAG,EAAE,GAAG,WAAW,KAA0B,EAAE;IAEpE,MAAM,GAAG,GAAG,IAAI,sBAAS,EAAE,CAAC;IAC5B,MAAM,OAAO,GAAG,IAAI,sBAAS,CAAC,OAAO,EAAE,CAAC;IACxC,MAAM,UAAU,GAAG,IAAA,8BAAsB,EAAC,UAAU,CAAC,CAAC;IAEtD,OAAO,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC;IAExC,QAAQ,gBAAgB,EAAE,CAAC;QACzB,KAAK,eAAG,CAAC,CAAC,CAAC;YACT,OAAO,CAAC,MAAM,CAAC,IAAI,iBAAK,EAAE,CAAC,CAAC;YAC5B,MAAM;QACR,CAAC;QACD,KAAK,qBAAS,CAAC,CAAC,CAAC;YACf,OAAO,CAAC,WAAW,CAAC,IAAI,iBAAK,EAAE,CAAC,CAAC;YACjC,MAAM;QACR,CAAC;QACD,OAAO,CAAC,CAAC,CAAC;YACR,OAAO,CAAC,WAAW,CAAC,gBAAgB,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC;YACnD,MAAM;QACR,CAAC;IACH,CAAC;IAED,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;IAExB,aAAK,CAAC,OAAO,CAAC,kBAAkB,EAAE;QAChC,UAAU;QACV,OAAO,EAAE,EAAE,gBAAgB,EAAE,GAAG,WAAW,EAAE;KAC9C,CAAC,CAAC;IACH,aAAK,CAAC,YAAY,CAAC,kBAAkB,EAAE,GAAG,CAAC,CAAC;IAE5C,OAAO,IAAI,CAAC,OAAO,CACjB,+BAAa,EACb,cAAc,EACd,CAAC,MAAM,EAAE,EAAE,CACT,IAAI,OAAO,CAAe,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QAC5C,MAAM,CAAC,MAAM,CACX,GAAG,EACH,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,EAClC,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;YACd,IAAI,KAAK,EAAE,CAAC;gBACV,OAAO,MAAM,CAAC,IAAA,6BAAqB,EAAC,KAAK,CAAC,CAAC,CAAC;YAC9C,CAAC;YAED,MAAM,MAAM,GAAiB,EAAE,CAAC;YAEhC,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;gBACvB,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,EAAG,CAAC;gBAEpC,MAAM,CAAC,QAAQ,GAAG;oBAChB,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;oBAC3C,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,kBAAkB,EAAE,CAAC;iBAC9C,CAAC;YACJ,CAAC;YAED,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC;QACzB,CAAC,CACF,CAAC;IACJ,CAAC,CAAC,CACL,CAAC;AACJ,CAAC,CAAC"}