@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.
- package/README.md +201 -0
- package/dist/Client/ServerFeatures.d.ts +17 -0
- package/dist/Client/ServerFeatures.js +56 -0
- package/dist/Client/ServerFeatures.js.map +1 -0
- package/dist/Client/discovery.d.ts +15 -0
- package/dist/Client/discovery.js +135 -0
- package/dist/Client/discovery.js.map +1 -0
- package/dist/Client/http.d.ts +19 -0
- package/dist/Client/http.js +97 -0
- package/dist/Client/http.js.map +1 -0
- package/dist/Client/index.d.ts +119 -0
- package/dist/Client/index.js +390 -0
- package/dist/Client/index.js.map +1 -0
- package/dist/Client/parseConnectionString.d.ts +23 -0
- package/dist/Client/parseConnectionString.js +238 -0
- package/dist/Client/parseConnectionString.js.map +1 -0
- package/dist/bridge/index.d.ts +66 -0
- package/dist/bridge/index.js +83 -0
- package/dist/bridge/index.js.map +1 -0
- package/dist/bridge/load.d.ts +1 -0
- package/dist/bridge/load.js +20 -0
- package/dist/bridge/load.js.map +1 -0
- package/dist/constants.d.ts +58 -0
- package/dist/constants.js +75 -0
- package/dist/constants.js.map +1 -0
- package/dist/events/binaryEvent.d.ts +16 -0
- package/dist/events/binaryEvent.js +14 -0
- package/dist/events/binaryEvent.js.map +1 -0
- package/dist/events/convertMetadata.d.ts +1 -0
- package/dist/events/convertMetadata.js +11 -0
- package/dist/events/convertMetadata.js.map +1 -0
- package/dist/events/index.d.ts +2 -0
- package/dist/events/index.js +19 -0
- package/dist/events/index.js.map +1 -0
- package/dist/events/jsonEvent.d.ts +8 -0
- package/dist/events/jsonEvent.js +14 -0
- package/dist/events/jsonEvent.js.map +1 -0
- package/dist/index.d.ts +13 -0
- package/dist/index.js +32 -0
- package/dist/index.js.map +1 -0
- package/dist/persistentSubscription/createPersistentSubscriptionToAll.d.ts +23 -0
- package/dist/persistentSubscription/createPersistentSubscriptionToAll.js +90 -0
- package/dist/persistentSubscription/createPersistentSubscriptionToAll.js.map +1 -0
- package/dist/persistentSubscription/createPersistentSubscriptionToStream.d.ts +17 -0
- package/dist/persistentSubscription/createPersistentSubscriptionToStream.js +49 -0
- package/dist/persistentSubscription/createPersistentSubscriptionToStream.js.map +1 -0
- package/dist/persistentSubscription/deletePersistentSubscriptionToAll.d.ts +13 -0
- package/dist/persistentSubscription/deletePersistentSubscriptionToAll.js +30 -0
- package/dist/persistentSubscription/deletePersistentSubscriptionToAll.js.map +1 -0
- package/dist/persistentSubscription/deletePersistentSubscriptionToStream.d.ts +13 -0
- package/dist/persistentSubscription/deletePersistentSubscriptionToStream.js +28 -0
- package/dist/persistentSubscription/deletePersistentSubscriptionToStream.js.map +1 -0
- package/dist/persistentSubscription/getPersistentSubscriptionToAllInfo.d.ts +13 -0
- package/dist/persistentSubscription/getPersistentSubscriptionToAllInfo.js +31 -0
- package/dist/persistentSubscription/getPersistentSubscriptionToAllInfo.js.map +1 -0
- package/dist/persistentSubscription/getPersistentSubscriptionToStreamInfo.d.ts +14 -0
- package/dist/persistentSubscription/getPersistentSubscriptionToStreamInfo.js +49 -0
- package/dist/persistentSubscription/getPersistentSubscriptionToStreamInfo.js.map +1 -0
- package/dist/persistentSubscription/index.d.ts +16 -0
- package/dist/persistentSubscription/index.js +33 -0
- package/dist/persistentSubscription/index.js.map +1 -0
- package/dist/persistentSubscription/listAllPersistentSubscriptions.d.ts +13 -0
- package/dist/persistentSubscription/listAllPersistentSubscriptions.js +42 -0
- package/dist/persistentSubscription/listAllPersistentSubscriptions.js.map +1 -0
- package/dist/persistentSubscription/listPersistentSubscriptionsToAll.d.ts +13 -0
- package/dist/persistentSubscription/listPersistentSubscriptionsToAll.js +33 -0
- package/dist/persistentSubscription/listPersistentSubscriptionsToAll.js.map +1 -0
- package/dist/persistentSubscription/listPersistentSubscriptionsToStream.d.ts +14 -0
- package/dist/persistentSubscription/listPersistentSubscriptionsToStream.js +51 -0
- package/dist/persistentSubscription/listPersistentSubscriptionsToStream.js.map +1 -0
- package/dist/persistentSubscription/replayParkedMessagesToAll.d.ts +18 -0
- package/dist/persistentSubscription/replayParkedMessagesToAll.js +36 -0
- package/dist/persistentSubscription/replayParkedMessagesToAll.js.map +1 -0
- package/dist/persistentSubscription/replayParkedMessagesToStream.d.ts +19 -0
- package/dist/persistentSubscription/replayParkedMessagesToStream.js +57 -0
- package/dist/persistentSubscription/replayParkedMessagesToStream.js.map +1 -0
- package/dist/persistentSubscription/restartPersistentSubscriptionSubsystem.d.ts +11 -0
- package/dist/persistentSubscription/restartPersistentSubscriptionSubsystem.js +30 -0
- package/dist/persistentSubscription/restartPersistentSubscriptionSubsystem.js.map +1 -0
- package/dist/persistentSubscription/subscribeToPersistentSubscriptionToAll.d.ts +20 -0
- package/dist/persistentSubscription/subscribeToPersistentSubscriptionToAll.js +38 -0
- package/dist/persistentSubscription/subscribeToPersistentSubscriptionToAll.js.map +1 -0
- package/dist/persistentSubscription/subscribeToPersistentSubscriptionToStream.d.ts +20 -0
- package/dist/persistentSubscription/subscribeToPersistentSubscriptionToStream.js +37 -0
- package/dist/persistentSubscription/subscribeToPersistentSubscriptionToStream.js.map +1 -0
- package/dist/persistentSubscription/updatePersistentSubscriptionToAll.d.ts +15 -0
- package/dist/persistentSubscription/updatePersistentSubscriptionToAll.js +53 -0
- package/dist/persistentSubscription/updatePersistentSubscriptionToAll.js.map +1 -0
- package/dist/persistentSubscription/updatePersistentSubscriptionToStream.d.ts +15 -0
- package/dist/persistentSubscription/updatePersistentSubscriptionToStream.js +49 -0
- package/dist/persistentSubscription/updatePersistentSubscriptionToStream.js.map +1 -0
- package/dist/persistentSubscription/utils/PersistentSubscriptionImpl.d.ts +18 -0
- package/dist/persistentSubscription/utils/PersistentSubscriptionImpl.js +112 -0
- package/dist/persistentSubscription/utils/PersistentSubscriptionImpl.js.map +1 -0
- package/dist/persistentSubscription/utils/mapPersistentSubscriptionInfo.d.ts +146 -0
- package/dist/persistentSubscription/utils/mapPersistentSubscriptionInfo.js +204 -0
- package/dist/persistentSubscription/utils/mapPersistentSubscriptionInfo.js.map +1 -0
- package/dist/persistentSubscription/utils/persistentSubscriptionSettings.d.ts +90 -0
- package/dist/persistentSubscription/utils/persistentSubscriptionSettings.js +39 -0
- package/dist/persistentSubscription/utils/persistentSubscriptionSettings.js.map +1 -0
- package/dist/persistentSubscription/utils/settingsToGRPC.d.ts +5 -0
- package/dist/persistentSubscription/utils/settingsToGRPC.js +49 -0
- package/dist/persistentSubscription/utils/settingsToGRPC.js.map +1 -0
- package/dist/projections/createProjection.d.ts +24 -0
- package/dist/projections/createProjection.js +48 -0
- package/dist/projections/createProjection.js.map +1 -0
- package/dist/projections/deleteProjection.d.ts +28 -0
- package/dist/projections/deleteProjection.js +33 -0
- package/dist/projections/deleteProjection.js.map +1 -0
- package/dist/projections/disableProjection.d.ts +19 -0
- package/dist/projections/disableProjection.js +34 -0
- package/dist/projections/disableProjection.js.map +1 -0
- package/dist/projections/enableProjection.d.ts +12 -0
- package/dist/projections/enableProjection.js +25 -0
- package/dist/projections/enableProjection.js.map +1 -0
- package/dist/projections/getProjectionResult.d.ts +17 -0
- package/dist/projections/getProjectionResult.js +29 -0
- package/dist/projections/getProjectionResult.js.map +1 -0
- package/dist/projections/getProjectionState.d.ts +17 -0
- package/dist/projections/getProjectionState.js +29 -0
- package/dist/projections/getProjectionState.js.map +1 -0
- package/dist/projections/getProjectionStatus.d.ts +12 -0
- package/dist/projections/getProjectionStatus.js +36 -0
- package/dist/projections/getProjectionStatus.js.map +1 -0
- package/dist/projections/index.d.ts +11 -0
- package/dist/projections/index.js +28 -0
- package/dist/projections/index.js.map +1 -0
- package/dist/projections/listProjections.d.ts +12 -0
- package/dist/projections/listProjections.js +36 -0
- package/dist/projections/listProjections.js.map +1 -0
- package/dist/projections/resetProjection.d.ts +13 -0
- package/dist/projections/resetProjection.js +25 -0
- package/dist/projections/resetProjection.js.map +1 -0
- package/dist/projections/restartSubsystem.d.ts +11 -0
- package/dist/projections/restartSubsystem.js +21 -0
- package/dist/projections/restartSubsystem.js.map +1 -0
- package/dist/projections/updateProjection.d.ts +20 -0
- package/dist/projections/updateProjection.js +34 -0
- package/dist/projections/updateProjection.js.map +1 -0
- package/dist/projections/utils/mapGrpcProjectionDetails.d.ts +3 -0
- package/dist/projections/utils/mapGrpcProjectionDetails.js +31 -0
- package/dist/projections/utils/mapGrpcProjectionDetails.js.map +1 -0
- package/dist/streams/appendToStream/append.d.ts +5 -0
- package/dist/streams/appendToStream/append.js +131 -0
- package/dist/streams/appendToStream/append.js.map +1 -0
- package/dist/streams/appendToStream/batchAppend.d.ts +5 -0
- package/dist/streams/appendToStream/batchAppend.js +145 -0
- package/dist/streams/appendToStream/batchAppend.js.map +1 -0
- package/dist/streams/appendToStream/index.d.ts +24 -0
- package/dist/streams/appendToStream/index.js +24 -0
- package/dist/streams/appendToStream/index.js.map +1 -0
- package/dist/streams/appendToStream/unpackError.d.ts +5 -0
- package/dist/streams/appendToStream/unpackError.js +54 -0
- package/dist/streams/appendToStream/unpackError.js.map +1 -0
- package/dist/streams/deleteStream.d.ts +18 -0
- package/dist/streams/deleteStream.js +51 -0
- package/dist/streams/deleteStream.js.map +1 -0
- package/dist/streams/getStreamMetadata.d.ts +27 -0
- package/dist/streams/getStreamMetadata.js +40 -0
- package/dist/streams/getStreamMetadata.js.map +1 -0
- package/dist/streams/index.d.ts +9 -0
- package/dist/streams/index.js +27 -0
- package/dist/streams/index.js.map +1 -0
- package/dist/streams/readAll.d.ts +35 -0
- package/dist/streams/readAll.js +37 -0
- package/dist/streams/readAll.js.map +1 -0
- package/dist/streams/readStream.d.ts +35 -0
- package/dist/streams/readStream.js +58 -0
- package/dist/streams/readStream.js.map +1 -0
- package/dist/streams/setStreamMetadata.d.ts +20 -0
- package/dist/streams/setStreamMetadata.js +20 -0
- package/dist/streams/setStreamMetadata.js.map +1 -0
- package/dist/streams/subscribeToAll.d.ts +30 -0
- package/dist/streams/subscribeToAll.js +89 -0
- package/dist/streams/subscribeToAll.js.map +1 -0
- package/dist/streams/subscribeToStream.d.ts +27 -0
- package/dist/streams/subscribeToStream.js +52 -0
- package/dist/streams/subscribeToStream.js.map +1 -0
- package/dist/streams/tombstoneStream.d.ts +18 -0
- package/dist/streams/tombstoneStream.js +51 -0
- package/dist/streams/tombstoneStream.js.map +1 -0
- package/dist/streams/utils/ReadStream.d.ts +14 -0
- package/dist/streams/utils/ReadStream.js +61 -0
- package/dist/streams/utils/ReadStream.js.map +1 -0
- package/dist/streams/utils/Subscription.d.ts +16 -0
- package/dist/streams/utils/Subscription.js +71 -0
- package/dist/streams/utils/Subscription.js.map +1 -0
- package/dist/streams/utils/streamMetadata.d.ts +53 -0
- package/dist/streams/utils/streamMetadata.js +77 -0
- package/dist/streams/utils/streamMetadata.js.map +1 -0
- package/dist/streams/utils/systemStreams.d.ts +20 -0
- package/dist/streams/utils/systemStreams.js +28 -0
- package/dist/streams/utils/systemStreams.js.map +1 -0
- package/dist/types/events.d.ts +157 -0
- package/dist/types/events.js +3 -0
- package/dist/types/events.js.map +1 -0
- package/dist/types/index.d.ts +348 -0
- package/dist/types/index.js +22 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/CommandError.d.ts +174 -0
- package/dist/utils/CommandError.js +403 -0
- package/dist/utils/CommandError.js.map +1 -0
- package/dist/utils/backpressuredWrite.d.ts +2 -0
- package/dist/utils/backpressuredWrite.js +50 -0
- package/dist/utils/backpressuredWrite.js.map +1 -0
- package/dist/utils/convertBridgeError.d.ts +1 -0
- package/dist/utils/convertBridgeError.js +41 -0
- package/dist/utils/convertBridgeError.js.map +1 -0
- package/dist/utils/convertGrpcEvent.d.ts +10 -0
- package/dist/utils/convertGrpcEvent.js +135 -0
- package/dist/utils/convertGrpcEvent.js.map +1 -0
- package/dist/utils/convertRustEvent.d.ts +4 -0
- package/dist/utils/convertRustEvent.js +85 -0
- package/dist/utils/convertRustEvent.js.map +1 -0
- package/dist/utils/debug.d.ts +7 -0
- package/dist/utils/debug.js +30 -0
- package/dist/utils/debug.js.map +1 -0
- package/dist/utils/filter.d.ts +44 -0
- package/dist/utils/filter.js +29 -0
- package/dist/utils/filter.js.map +1 -0
- package/dist/utils/grpcStreamIdentifier.d.ts +2 -0
- package/dist/utils/grpcStreamIdentifier.js +11 -0
- package/dist/utils/grpcStreamIdentifier.js.map +1 -0
- package/dist/utils/grpcUUID.d.ts +4 -0
- package/dist/utils/grpcUUID.js +29 -0
- package/dist/utils/grpcUUID.js.map +1 -0
- package/dist/utils/index.d.ts +9 -0
- package/dist/utils/index.js +26 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/isClientCancellationError.d.ts +1 -0
- package/dist/utils/isClientCancellationError.js +13 -0
- package/dist/utils/isClientCancellationError.js.map +1 -0
- package/dist/utils/utilityTypes.d.ts +2 -0
- package/dist/utils/utilityTypes.js +3 -0
- package/dist/utils/utilityTypes.js.map +1 -0
- package/generated/cluster_grpc_pb.d.ts +211 -0
- package/generated/cluster_grpc_pb.js +247 -0
- package/generated/cluster_pb.d.ts +546 -0
- package/generated/cluster_pb.js +4357 -0
- package/generated/code_grpc_pb.js +1 -0
- package/generated/code_pb.d.ts +27 -0
- package/generated/code_pb.js +48 -0
- package/generated/gossip_grpc_pb.d.ts +42 -0
- package/generated/gossip_grpc_pb.js +45 -0
- package/generated/gossip_pb.d.ts +111 -0
- package/generated/gossip_pb.js +727 -0
- package/generated/monitoring_grpc_pb.d.ts +39 -0
- package/generated/monitoring_grpc_pb.js +44 -0
- package/generated/monitoring_pb.d.ts +52 -0
- package/generated/monitoring_pb.js +361 -0
- package/generated/operations_grpc_pb.d.ts +144 -0
- package/generated/operations_grpc_pb.js +144 -0
- package/generated/operations_pb.d.ts +151 -0
- package/generated/operations_pb.js +1050 -0
- package/generated/persistent_grpc_pb.d.ts +160 -0
- package/generated/persistent_grpc_pb.js +265 -0
- package/generated/persistent_pb.d.ts +1702 -0
- package/generated/persistent_pb.js +12340 -0
- package/generated/projections_grpc_pb.d.ts +194 -0
- package/generated/projections_grpc_pb.js +332 -0
- package/generated/projections_pb.d.ts +821 -0
- package/generated/projections_pb.js +6065 -0
- package/generated/serverfeatures_grpc_pb.d.ts +42 -0
- package/generated/serverfeatures_grpc_pb.js +45 -0
- package/generated/serverfeatures_pb.d.ts +61 -0
- package/generated/serverfeatures_pb.js +476 -0
- package/generated/shared_grpc_pb.js +1 -0
- package/generated/shared_pb.d.ts +335 -0
- package/generated/shared_pb.js +2374 -0
- package/generated/status_grpc_pb.js +1 -0
- package/generated/status_pb.d.ts +38 -0
- package/generated/status_pb.js +261 -0
- package/generated/streams_grpc_pb.d.ts +112 -0
- package/generated/streams_grpc_pb.js +180 -0
- package/generated/streams_pb.d.ts +1660 -0
- package/generated/streams_pb.js +11556 -0
- package/generated/users_grpc_pb.d.ts +158 -0
- package/generated/users_grpc_pb.js +275 -0
- package/generated/users_pb.d.ts +601 -0
- package/generated/users_pb.js +4451 -0
- 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,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"}
|