@zeeshan60/event-processor 1.0.20 → 1.0.21
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/dist/BaseEventHandler.d.ts +5 -0
- package/dist/BaseEventHandler.d.ts.map +1 -1
- package/dist/BaseEventHandler.js +13 -0
- package/dist/BaseEventHandler.js.map +1 -1
- package/dist/FriendEventHandler.d.ts +4 -2
- package/dist/FriendEventHandler.d.ts.map +1 -1
- package/dist/FriendEventHandler.js +86 -4
- package/dist/FriendEventHandler.js.map +1 -1
- package/dist/TransactionEventHandler.d.ts +1 -0
- package/dist/TransactionEventHandler.d.ts.map +1 -1
- package/dist/TransactionEventHandler.js +57 -26
- package/dist/TransactionEventHandler.js.map +1 -1
- package/dist/UserEventHandler.d.ts +1 -0
- package/dist/UserEventHandler.d.ts.map +1 -1
- package/dist/UserEventHandler.js +52 -9
- package/dist/UserEventHandler.js.map +1 -1
- package/dist/errors/RetryError.d.ts +6 -0
- package/dist/errors/RetryError.d.ts.map +1 -0
- package/dist/errors/RetryError.js +13 -0
- package/dist/errors/RetryError.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +6 -1
- package/dist/index.js.map +1 -1
- package/dist/utils/tryLater.d.ts +12 -0
- package/dist/utils/tryLater.d.ts.map +1 -0
- package/dist/utils/tryLater.js +27 -0
- package/dist/utils/tryLater.js.map +1 -0
- package/package.json +1 -1
|
@@ -12,5 +12,10 @@ export declare abstract class BaseEventHandler<T extends Event> {
|
|
|
12
12
|
abstract handleClientEventsFromRemoteListenerBulk(events: T[]): Promise<void>;
|
|
13
13
|
abstract getModelStore(): ModelStore;
|
|
14
14
|
protected shouldSkipSave(existingModel: Model | undefined, updatedModel: Model): boolean;
|
|
15
|
+
protected shouldTryLater(existingModel: Model | undefined, updatedModel: Model): {
|
|
16
|
+
shouldRetry: boolean;
|
|
17
|
+
delayMs: number;
|
|
18
|
+
versionGap: number;
|
|
19
|
+
};
|
|
15
20
|
}
|
|
16
21
|
//# sourceMappingURL=BaseEventHandler.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BaseEventHandler.d.ts","sourceRoot":"","sources":["../src/BaseEventHandler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEzD,8BAAsB,gBAAgB,CAAC,CAAC,SAAS,KAAK;IAClD,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,OAAO,CAAC;IACrC,SAAS,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAAE,kBAAkB,CAAC;gBAE/C,QAAQ,EAAE,OAAO,EAAE,kBAAkB,CAAC,EAAE,kBAAkB;IAKtE,QAAQ,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,EAAE,OAAO,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,GAAG,CAAC;IACtE,QAAQ,CAAC,mCAAmC,CAAC,KAAK,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IACrE,QAAQ,CAAC,wCAAwC,CAC7C,MAAM,EAAE,CAAC,EAAE,GACZ,OAAO,CAAC,IAAI,CAAC;IAChB,QAAQ,CAAC,aAAa,IAAI,UAAU;IAEpC,SAAS,CAAC,cAAc,CACpB,aAAa,EAAE,KAAK,GAAG,SAAS,EAChC,YAAY,EAAE,KAAK,GACpB,OAAO;
|
|
1
|
+
{"version":3,"file":"BaseEventHandler.d.ts","sourceRoot":"","sources":["../src/BaseEventHandler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEzD,8BAAsB,gBAAgB,CAAC,CAAC,SAAS,KAAK;IAClD,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,OAAO,CAAC;IACrC,SAAS,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAAE,kBAAkB,CAAC;gBAE/C,QAAQ,EAAE,OAAO,EAAE,kBAAkB,CAAC,EAAE,kBAAkB;IAKtE,QAAQ,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,EAAE,OAAO,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,GAAG,CAAC;IACtE,QAAQ,CAAC,mCAAmC,CAAC,KAAK,EAAE,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IACrE,QAAQ,CAAC,wCAAwC,CAC7C,MAAM,EAAE,CAAC,EAAE,GACZ,OAAO,CAAC,IAAI,CAAC;IAChB,QAAQ,CAAC,aAAa,IAAI,UAAU;IAEpC,SAAS,CAAC,cAAc,CACpB,aAAa,EAAE,KAAK,GAAG,SAAS,EAChC,YAAY,EAAE,KAAK,GACpB,OAAO;IAUV,SAAS,CAAC,cAAc,CACpB,aAAa,EAAE,KAAK,GAAG,SAAS,EAChC,YAAY,EAAE,KAAK,GACpB;QAAE,WAAW,EAAE,OAAO,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE;CAiBnE"}
|
package/dist/BaseEventHandler.js
CHANGED
|
@@ -13,6 +13,19 @@ class BaseEventHandler {
|
|
|
13
13
|
return (existingModel.streamId === updatedModel.streamId &&
|
|
14
14
|
existingModel.version >= updatedModel.version);
|
|
15
15
|
}
|
|
16
|
+
shouldTryLater(existingModel, updatedModel) {
|
|
17
|
+
if (!existingModel) {
|
|
18
|
+
return { shouldRetry: false, delayMs: 0, versionGap: 0 };
|
|
19
|
+
}
|
|
20
|
+
const expectedVersion = existingModel.version + 1;
|
|
21
|
+
const receivedVersion = updatedModel.version;
|
|
22
|
+
if (receivedVersion <= expectedVersion) {
|
|
23
|
+
return { shouldRetry: false, delayMs: 0, versionGap: 0 };
|
|
24
|
+
}
|
|
25
|
+
const versionGap = receivedVersion - existingModel.version;
|
|
26
|
+
const delayMs = versionGap * 50;
|
|
27
|
+
return { shouldRetry: true, delayMs, versionGap };
|
|
28
|
+
}
|
|
16
29
|
}
|
|
17
30
|
exports.BaseEventHandler = BaseEventHandler;
|
|
18
31
|
//# sourceMappingURL=BaseEventHandler.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BaseEventHandler.js","sourceRoot":"","sources":["../src/BaseEventHandler.ts"],"names":[],"mappings":";;;AAMA,MAAsB,gBAAgB;IAIlC,YAAY,QAAiB,EAAE,kBAAuC;QAClE,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC;IACjD,CAAC;IASS,cAAc,CACpB,aAAgC,EAChC,YAAmB;QAEnB,IAAI,CAAC,aAAa,EAAE,CAAC;YACjB,OAAO,KAAK,CAAC;QACjB,CAAC;QACD,OAAO,CACH,aAAa,CAAC,QAAQ,KAAK,YAAY,CAAC,QAAQ;YAChD,aAAa,CAAC,OAAO,IAAI,YAAY,CAAC,OAAO,CAChD,CAAC;IACN,CAAC;CACJ;
|
|
1
|
+
{"version":3,"file":"BaseEventHandler.js","sourceRoot":"","sources":["../src/BaseEventHandler.ts"],"names":[],"mappings":";;;AAMA,MAAsB,gBAAgB;IAIlC,YAAY,QAAiB,EAAE,kBAAuC;QAClE,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC;IACjD,CAAC;IASS,cAAc,CACpB,aAAgC,EAChC,YAAmB;QAEnB,IAAI,CAAC,aAAa,EAAE,CAAC;YACjB,OAAO,KAAK,CAAC;QACjB,CAAC;QACD,OAAO,CACH,aAAa,CAAC,QAAQ,KAAK,YAAY,CAAC,QAAQ;YAChD,aAAa,CAAC,OAAO,IAAI,YAAY,CAAC,OAAO,CAChD,CAAC;IACN,CAAC;IAES,cAAc,CACpB,aAAgC,EAChC,YAAmB;QAEnB,IAAI,CAAC,aAAa,EAAE,CAAC;YACjB,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC;QAC7D,CAAC;QAED,MAAM,eAAe,GAAG,aAAa,CAAC,OAAO,GAAG,CAAC,CAAC;QAClD,MAAM,eAAe,GAAG,YAAY,CAAC,OAAO,CAAC;QAE7C,IAAI,eAAe,IAAI,eAAe,EAAE,CAAC;YACrC,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC;QAC7D,CAAC;QAED,MAAM,UAAU,GAAG,eAAe,GAAG,aAAa,CAAC,OAAO,CAAC;QAC3D,MAAM,OAAO,GAAG,UAAU,GAAG,EAAE,CAAC;QAEhC,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC;IACtD,CAAC;CACJ;AAjDD,4CAiDC"}
|
|
@@ -13,8 +13,10 @@ export declare class FriendEventHandler extends BaseEventHandler<FriendEvent> {
|
|
|
13
13
|
handleClientEventFromRemoteListener(event: FriendEvent): Promise<void>;
|
|
14
14
|
handleClientEventsFromRemoteListenerBulk(events: FriendEvent[]): Promise<void>;
|
|
15
15
|
handleEvent(event: FriendEvent, context?: import("./common/LoggingContext").LoggingContext): Promise<void>;
|
|
16
|
-
handleFriendCreated(event: FriendCreated): Promise<void>;
|
|
17
|
-
|
|
16
|
+
handleFriendCreated(event: FriendCreated, context?: import("./common/LoggingContext").LoggingContext): Promise<void>;
|
|
17
|
+
private _handleFriendCreatedWithRetryCheck;
|
|
18
|
+
handleGenericFriendEvent(event: FriendEvent, context?: import("./common/LoggingContext").LoggingContext): Promise<void>;
|
|
19
|
+
private _handleGenericFriendEventWithRetryCheck;
|
|
18
20
|
handleFriendCreatedOnBackend(event: FriendCreated): Promise<void>;
|
|
19
21
|
private handleFriendCreatedServer;
|
|
20
22
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FriendEventHandler.d.ts","sourceRoot":"","sources":["../src/FriendEventHandler.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,aAAa,EACb,WAAW,EACX,gBAAgB,EAGhB,gBAAgB,EAGhB,cAAc,EAEd,cAAc,EACjB,MAAM,GAAG,CAAC;AACX,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAE9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"FriendEventHandler.d.ts","sourceRoot":"","sources":["../src/FriendEventHandler.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,aAAa,EACb,WAAW,EACX,gBAAgB,EAGhB,gBAAgB,EAGhB,cAAc,EAEd,cAAc,EACjB,MAAM,GAAG,CAAC;AACX,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAE9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAI1D,qBAAa,kBAAmB,SAAQ,gBAAgB,CAAC,WAAW,CAAC;IAE7D,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,cAAc;IACtB,OAAO,CAAC,gBAAgB;IACxB,OAAO,CAAC,cAAc;IAGtB,OAAO,CAAC,oBAAoB,CAAC;gBANrB,UAAU,EAAE,gBAAgB,EAC5B,cAAc,EAAE,cAAc,EAC9B,gBAAgB,EAAE,gBAAgB,EAClC,cAAc,EAAE,cAAc,EACtC,QAAQ,EAAE,OAAO,EACjB,kBAAkB,CAAC,EAAE,kBAAkB,EAC/B,oBAAoB,CAAC,EAAE,oBAAoB,YAAA;IAKhD,aAAa,IAAI,gBAAgB;IAI3B,mCAAmC,CAC5C,KAAK,EAAE,WAAW,GACnB,OAAO,CAAC,IAAI,CAAC;IAWH,wCAAwC,CACjD,MAAM,EAAE,WAAW,EAAE,GACtB,OAAO,CAAC,IAAI,CAAC;IAqBV,WAAW,CACb,KAAK,EAAE,WAAW,EAClB,OAAO,CAAC,EAAE,OAAO,yBAAyB,EAAE,cAAc,GAC3D,OAAO,CAAC,IAAI,CAAC;IAcV,mBAAmB,CACrB,KAAK,EAAE,aAAa,EACpB,OAAO,CAAC,EAAE,OAAO,yBAAyB,EAAE,cAAc,GAC3D,OAAO,CAAC,IAAI,CAAC;YAqBF,kCAAkC;IA2D1C,wBAAwB,CAC1B,KAAK,EAAE,WAAW,EAClB,OAAO,CAAC,EAAE,OAAO,yBAAyB,EAAE,cAAc,GAC3D,OAAO,CAAC,IAAI,CAAC;YAqBF,uCAAuC;IA4D/C,4BAA4B,CAAC,KAAK,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC;YAYzD,yBAAyB;CA4I1C"}
|
|
@@ -4,6 +4,8 @@ exports.FriendEventHandler = void 0;
|
|
|
4
4
|
const _1 = require(".");
|
|
5
5
|
const BaseEventHandler_1 = require("./BaseEventHandler");
|
|
6
6
|
const uuid_1 = require("uuid");
|
|
7
|
+
const tryLater_1 = require("./utils/tryLater");
|
|
8
|
+
const RetryError_1 = require("./errors/RetryError");
|
|
7
9
|
class FriendEventHandler extends BaseEventHandler_1.BaseEventHandler {
|
|
8
10
|
constructor(modelStore, userModelStore, friendEventStore, userEventStore, isClient, modelChangeEmitter, activityEventHandler) {
|
|
9
11
|
super(isClient, modelChangeEmitter);
|
|
@@ -44,17 +46,57 @@ class FriendEventHandler extends BaseEventHandler_1.BaseEventHandler {
|
|
|
44
46
|
const eventType = event.constructor.name;
|
|
45
47
|
switch (eventType) {
|
|
46
48
|
case "FriendCreated":
|
|
47
|
-
return await this.handleFriendCreated(event);
|
|
49
|
+
return await this.handleFriendCreated(event, context);
|
|
48
50
|
default:
|
|
49
|
-
return await this.handleGenericFriendEvent(event);
|
|
51
|
+
return await this.handleGenericFriendEvent(event, context);
|
|
50
52
|
}
|
|
51
53
|
}
|
|
52
|
-
async handleFriendCreated(event) {
|
|
54
|
+
async handleFriendCreated(event, context) {
|
|
55
|
+
const maxRetries = 3;
|
|
56
|
+
for (let attempt = 1; attempt <= maxRetries; attempt++) {
|
|
57
|
+
try {
|
|
58
|
+
return await this._handleFriendCreatedWithRetryCheck(event, context, attempt);
|
|
59
|
+
}
|
|
60
|
+
catch (error) {
|
|
61
|
+
if (error instanceof RetryError_1.RetryError && attempt < maxRetries) {
|
|
62
|
+
continue;
|
|
63
|
+
}
|
|
64
|
+
throw error;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
throw new Error("Max retries exhausted");
|
|
68
|
+
}
|
|
69
|
+
async _handleFriendCreatedWithRetryCheck(event, context, attempt) {
|
|
53
70
|
const existingModel = await this.modelStore.getByStreamIdWhereDeletedIsFalse(event.streamId);
|
|
54
71
|
const updatedModel = event.apply(existingModel);
|
|
55
72
|
if (this.shouldSkipSave(existingModel, updatedModel)) {
|
|
56
73
|
return;
|
|
57
74
|
}
|
|
75
|
+
const retryCheck = this.shouldTryLater(existingModel, updatedModel);
|
|
76
|
+
if (retryCheck.shouldRetry) {
|
|
77
|
+
context?.logger?.info("[FriendEventHandler] Version gap detected", {
|
|
78
|
+
requestId: context?.requestId,
|
|
79
|
+
eventType: "FriendCreated",
|
|
80
|
+
streamId: event.streamId,
|
|
81
|
+
existingVersion: existingModel?.version,
|
|
82
|
+
eventVersion: updatedModel.version,
|
|
83
|
+
versionGap: retryCheck.versionGap,
|
|
84
|
+
delayMs: retryCheck.delayMs,
|
|
85
|
+
attempt,
|
|
86
|
+
});
|
|
87
|
+
await (0, tryLater_1.tryLater)({
|
|
88
|
+
shouldRetry: true,
|
|
89
|
+
delayMs: retryCheck.delayMs,
|
|
90
|
+
versionGap: retryCheck.versionGap,
|
|
91
|
+
maxRetries: 3,
|
|
92
|
+
currentAttempt: attempt,
|
|
93
|
+
context,
|
|
94
|
+
logContext: {
|
|
95
|
+
eventType: "FriendCreated",
|
|
96
|
+
streamId: event.streamId,
|
|
97
|
+
},
|
|
98
|
+
});
|
|
99
|
+
}
|
|
58
100
|
await this.modelStore.save(updatedModel);
|
|
59
101
|
if (this.isClient) {
|
|
60
102
|
await this.friendEventStore.addEvent(event);
|
|
@@ -67,12 +109,52 @@ class FriendEventHandler extends BaseEventHandler_1.BaseEventHandler {
|
|
|
67
109
|
await this.handleFriendCreatedServer(event, updatedModel);
|
|
68
110
|
}
|
|
69
111
|
}
|
|
70
|
-
async handleGenericFriendEvent(event) {
|
|
112
|
+
async handleGenericFriendEvent(event, context) {
|
|
113
|
+
const maxRetries = 3;
|
|
114
|
+
for (let attempt = 1; attempt <= maxRetries; attempt++) {
|
|
115
|
+
try {
|
|
116
|
+
return await this._handleGenericFriendEventWithRetryCheck(event, context, attempt);
|
|
117
|
+
}
|
|
118
|
+
catch (error) {
|
|
119
|
+
if (error instanceof RetryError_1.RetryError && attempt < maxRetries) {
|
|
120
|
+
continue;
|
|
121
|
+
}
|
|
122
|
+
throw error;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
throw new Error("Max retries exhausted");
|
|
126
|
+
}
|
|
127
|
+
async _handleGenericFriendEventWithRetryCheck(event, context, attempt) {
|
|
71
128
|
const existingModel = await this.modelStore.getByStreamIdWhereDeletedIsFalse(event.streamId);
|
|
72
129
|
const updatedModel = event.apply(existingModel);
|
|
73
130
|
if (this.shouldSkipSave(existingModel, updatedModel)) {
|
|
74
131
|
return;
|
|
75
132
|
}
|
|
133
|
+
const retryCheck = this.shouldTryLater(existingModel, updatedModel);
|
|
134
|
+
if (retryCheck.shouldRetry) {
|
|
135
|
+
context?.logger?.info("[FriendEventHandler] Version gap detected", {
|
|
136
|
+
requestId: context?.requestId,
|
|
137
|
+
eventType: event.constructor.name,
|
|
138
|
+
streamId: event.streamId,
|
|
139
|
+
existingVersion: existingModel?.version,
|
|
140
|
+
eventVersion: updatedModel.version,
|
|
141
|
+
versionGap: retryCheck.versionGap,
|
|
142
|
+
delayMs: retryCheck.delayMs,
|
|
143
|
+
attempt,
|
|
144
|
+
});
|
|
145
|
+
await (0, tryLater_1.tryLater)({
|
|
146
|
+
shouldRetry: true,
|
|
147
|
+
delayMs: retryCheck.delayMs,
|
|
148
|
+
versionGap: retryCheck.versionGap,
|
|
149
|
+
maxRetries: 3,
|
|
150
|
+
currentAttempt: attempt,
|
|
151
|
+
context,
|
|
152
|
+
logContext: {
|
|
153
|
+
eventType: event.constructor.name,
|
|
154
|
+
streamId: event.streamId,
|
|
155
|
+
},
|
|
156
|
+
});
|
|
157
|
+
}
|
|
76
158
|
await this.modelStore.save(updatedModel);
|
|
77
159
|
if (this.isClient) {
|
|
78
160
|
await this.friendEventStore.addEvent(event);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FriendEventHandler.js","sourceRoot":"","sources":["../src/FriendEventHandler.ts"],"names":[],"mappings":";;;AAAA,wBAYW;AACX,yDAAsD;AAEtD,+BAAoC;
|
|
1
|
+
{"version":3,"file":"FriendEventHandler.js","sourceRoot":"","sources":["../src/FriendEventHandler.ts"],"names":[],"mappings":";;;AAAA,wBAYW;AACX,yDAAsD;AAEtD,+BAAoC;AAEpC,+CAA4C;AAC5C,oDAAiD;AAEjD,MAAa,kBAAmB,SAAQ,mCAA6B;IACjE,YACY,UAA4B,EAC5B,cAA8B,EAC9B,gBAAkC,EAClC,cAA8B,EACtC,QAAiB,EACjB,kBAAuC,EAC/B,oBAA2C;QAEnD,KAAK,CAAC,QAAQ,EAAE,kBAAkB,CAAC,CAAC;QAR5B,eAAU,GAAV,UAAU,CAAkB;QAC5B,mBAAc,GAAd,cAAc,CAAgB;QAC9B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,mBAAc,GAAd,cAAc,CAAgB;QAG9B,yBAAoB,GAApB,oBAAoB,CAAuB;IAGvD,CAAC;IAEM,aAAa;QAChB,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAEM,KAAK,CAAC,mCAAmC,CAC5C,KAAkB;QAElB,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,CACrD,KAAK,CAAC,QAAQ,CACjB,CAAC;QACF,MAAM,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC,aAAa,CAAgB,CAAC;QAC/D,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,YAAY,CAAC,EAAE,CAAC;YACpD,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACzC,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;QAC/D,CAAC;IACL,CAAC;IAEM,KAAK,CAAC,wCAAwC,CACjD,MAAqB;QAErB,MAAM,aAAa,GAAkB,EAAE,CAAC;QAExC,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;YACzB,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,CACrD,KAAK,CAAC,QAAQ,CACjB,CAAC;YACF,MAAM,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC,aAAa,CAAgB,CAAC;YAC/D,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,YAAY,CAAC,EAAE,CAAC;gBACpD,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBACzC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACrC,CAAC;QACL,CAAC;QAED,IAAI,IAAI,CAAC,kBAAkB,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtD,KAAK,MAAM,KAAK,IAAI,aAAa,EAAE,CAAC;gBAChC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;YACvD,CAAC;QACL,CAAC;IACL,CAAC;IAED,KAAK,CAAC,WAAW,CACb,KAAkB,EAClB,OAA0D;QAE1D,MAAM,SAAS,GAAG,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC;QAEzC,QAAQ,SAAS,EAAE,CAAC;YAChB,KAAK,eAAe;gBAChB,OAAO,MAAM,IAAI,CAAC,mBAAmB,CACjC,KAAsB,EACtB,OAAO,CACV,CAAC;YACN;gBACI,OAAO,MAAM,IAAI,CAAC,wBAAwB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QACnE,CAAC;IACL,CAAC;IAED,KAAK,CAAC,mBAAmB,CACrB,KAAoB,EACpB,OAA0D;QAE1D,MAAM,UAAU,GAAG,CAAC,CAAC;QAErB,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,IAAI,UAAU,EAAE,OAAO,EAAE,EAAE,CAAC;YACrD,IAAI,CAAC;gBACD,OAAO,MAAM,IAAI,CAAC,kCAAkC,CAChD,KAAK,EACL,OAAO,EACP,OAAO,CACV,CAAC;YACN,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACb,IAAI,KAAK,YAAY,uBAAU,IAAI,OAAO,GAAG,UAAU,EAAE,CAAC;oBACtD,SAAS;gBACb,CAAC;gBACD,MAAM,KAAK,CAAC;YAChB,CAAC;QACL,CAAC;QAED,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;IAC7C,CAAC;IAEO,KAAK,CAAC,kCAAkC,CAC5C,KAAoB,EACpB,OAAqE,EACrE,OAAe;QAEf,MAAM,aAAa,GACf,MAAM,IAAI,CAAC,UAAU,CAAC,gCAAgC,CAClD,KAAK,CAAC,QAAQ,CACjB,CAAC;QACN,MAAM,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC,aAAa,CAAgB,CAAC;QAE/D,IAAI,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,YAAY,CAAC,EAAE,CAAC;YACnD,OAAO;QACX,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;QACpE,IAAI,UAAU,CAAC,WAAW,EAAE,CAAC;YACzB,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,2CAA2C,EAAE;gBAC/D,SAAS,EAAE,OAAO,EAAE,SAAS;gBAC7B,SAAS,EAAE,eAAe;gBAC1B,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,eAAe,EAAE,aAAa,EAAE,OAAO;gBACvC,YAAY,EAAE,YAAY,CAAC,OAAO;gBAClC,UAAU,EAAE,UAAU,CAAC,UAAU;gBACjC,OAAO,EAAE,UAAU,CAAC,OAAO;gBAC3B,OAAO;aACV,CAAC,CAAC;YAEH,MAAM,IAAA,mBAAQ,EAAC;gBACX,WAAW,EAAE,IAAI;gBACjB,OAAO,EAAE,UAAU,CAAC,OAAO;gBAC3B,UAAU,EAAE,UAAU,CAAC,UAAU;gBACjC,UAAU,EAAE,CAAC;gBACb,cAAc,EAAE,OAAO;gBACvB,OAAO;gBACP,UAAU,EAAE;oBACR,SAAS,EAAE,eAAe;oBAC1B,QAAQ,EAAE,KAAK,CAAC,QAAQ;iBAC3B;aACJ,CAAC,CAAC;QACP,CAAC;QAED,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAEzC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAC5C,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;YAC3D,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAC5B,MAAM,IAAI,CAAC,oBAAoB,CAAC,iBAAiB,CAC7C,KAAK,EACL,aAAa,EACb,YAAY,CACf,CAAC;YACN,CAAC;QACL,CAAC;aAAM,CAAC;YACJ,MAAM,IAAI,CAAC,yBAAyB,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;QAC9D,CAAC;IACL,CAAC;IAED,KAAK,CAAC,wBAAwB,CAC1B,KAAkB,EAClB,OAA0D;QAE1D,MAAM,UAAU,GAAG,CAAC,CAAC;QAErB,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,IAAI,UAAU,EAAE,OAAO,EAAE,EAAE,CAAC;YACrD,IAAI,CAAC;gBACD,OAAO,MAAM,IAAI,CAAC,uCAAuC,CACrD,KAAK,EACL,OAAO,EACP,OAAO,CACV,CAAC;YACN,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACb,IAAI,KAAK,YAAY,uBAAU,IAAI,OAAO,GAAG,UAAU,EAAE,CAAC;oBACtD,SAAS;gBACb,CAAC;gBACD,MAAM,KAAK,CAAC;YAChB,CAAC;QACL,CAAC;QAED,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;IAC7C,CAAC;IAEO,KAAK,CAAC,uCAAuC,CACjD,KAAkB,EAClB,OAAqE,EACrE,OAAe;QAEf,MAAM,aAAa,GACf,MAAM,IAAI,CAAC,UAAU,CAAC,gCAAgC,CAClD,KAAK,CAAC,QAAQ,CACjB,CAAC;QACN,MAAM,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC,aAAa,CAAgB,CAAC;QAE/D,IAAI,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,YAAY,CAAC,EAAE,CAAC;YACnD,OAAO;QACX,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;QACpE,IAAI,UAAU,CAAC,WAAW,EAAE,CAAC;YACzB,OAAO,EAAE,MAAM,EAAE,IAAI,CACjB,2CAA2C,EAC3C;gBACI,SAAS,EAAE,OAAO,EAAE,SAAS;gBAC7B,SAAS,EAAE,KAAK,CAAC,WAAW,CAAC,IAAI;gBACjC,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,eAAe,EAAE,aAAa,EAAE,OAAO;gBACvC,YAAY,EAAE,YAAY,CAAC,OAAO;gBAClC,UAAU,EAAE,UAAU,CAAC,UAAU;gBACjC,OAAO,EAAE,UAAU,CAAC,OAAO;gBAC3B,OAAO;aACV,CACJ,CAAC;YAEF,MAAM,IAAA,mBAAQ,EAAC;gBACX,WAAW,EAAE,IAAI;gBACjB,OAAO,EAAE,UAAU,CAAC,OAAO;gBAC3B,UAAU,EAAE,UAAU,CAAC,UAAU;gBACjC,UAAU,EAAE,CAAC;gBACb,cAAc,EAAE,OAAO;gBACvB,OAAO;gBACP,UAAU,EAAE;oBACR,SAAS,EAAE,KAAK,CAAC,WAAW,CAAC,IAAI;oBACjC,QAAQ,EAAE,KAAK,CAAC,QAAQ;iBAC3B;aACJ,CAAC,CAAC;QACP,CAAC;QAED,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAEzC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YAC5C,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;YAC3D,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAC5B,MAAM,IAAI,CAAC,oBAAoB,CAAC,iBAAiB,CAC7C,KAAK,EACL,aAAa,EACb,YAAY,CACf,CAAC;YACN,CAAC;QACL,CAAC;IACL,CAAC;IAED,KAAK,CAAC,4BAA4B,CAAC,KAAoB;QACnD,MAAM,aAAa,GACf,MAAM,IAAI,CAAC,UAAU,CAAC,gCAAgC,CAClD,KAAK,CAAC,QAAQ,CACjB,CAAC;QACN,MAAM,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC,aAAa,CAAgB,CAAC;QAC/D,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,YAAY,CAAC,EAAE,CAAC;YACpD,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC7C,CAAC;QACD,MAAM,IAAI,CAAC,yBAAyB,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;IAC9D,CAAC;IAEO,KAAK,CAAC,yBAAyB,CACnC,KAAoB,EACpB,YAAyB;QAEzB,kEAAkE;QAClE,IAAI,UAAU,GAAG,IAAI,CAAC;QACtB,IAAI,KAAK,CAAC,iBAAiB,EAAE,CAAC;YAC1B,UAAU,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,WAAW,CAC9C,KAAK,CAAC,iBAAiB,CAC1B,CAAC;QACN,CAAC;QACD,IAAI,CAAC,UAAU,IAAI,KAAK,CAAC,WAAW,EAAE,CAAC;YACnC,UAAU,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,WAAW,CAC9C,KAAK,CAAC,WAAW,CACpB,CAAC;QACN,CAAC;QAED,kEAAkE;QAClE,IAAI,UAAU,EAAE,CAAC;YACb,8CAA8C;YAC9C,MAAM,kBAAkB,GAAG,IAAI,gBAAa,CAAC;gBACzC,OAAO,EAAE,IAAA,SAAM,GAAE;gBACjB,MAAM,EAAE,KAAK,CAAC,MAAM;gBACpB,QAAQ,EAAE,UAAU,CAAC,MAAM;gBAC3B,SAAS,EAAE,IAAI,IAAI,EAAE;gBACrB,SAAS,EAAE,KAAK,CAAC,MAAM;gBACvB,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,OAAO,EAAE,YAAY,CAAC,OAAO,GAAG,CAAC;gBACjC,eAAe,EAAE,IAAI;aACxB,CAAC,CAAC;YACH,MAAM,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC;YACzD,MAAM,iBAAiB,GAAG,kBAAkB,CAAC,KAAK,CAC9C,YAAY,CACA,CAAC;YACjB,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;YAE9C,MAAM,WAAW,GACb,MAAM,IAAI,CAAC,cAAc,CAAC,gCAAgC,CACtD,KAAK,CAAC,MAAM,CACf,CAAC;YACN,IAAI,WAAW,EAAE,CAAC;gBACd,MAAM,uBAAuB,GAAG,IAAI,gBAAa,CAAC;oBAC9C,OAAO,EAAE,IAAA,SAAM,GAAE;oBACjB,MAAM,EAAE,UAAU,CAAC,MAAM;oBACzB,WAAW,EAAE,WAAW,CAAC,KAAK;oBAC9B,iBAAiB,EAAE,WAAW,CAAC,WAAW;oBAC1C,iBAAiB,EAAE,WAAW,CAAC,WAAW;oBAC1C,QAAQ,EAAE,KAAK,CAAC,MAAM;oBACtB,OAAO,EAAE,KAAK,CAAC,OAAO;oBACtB,SAAS,EAAE,IAAI,IAAI,EAAE;oBACrB,SAAS,EAAE,UAAU,CAAC,MAAM;oBAC5B,QAAQ,EAAE,IAAA,SAAM,GAAE;oBAClB,OAAO,EAAE,CAAC;oBACV,eAAe,EAAE,IAAI;iBACxB,CAAC,CAAC;gBACH,MAAM,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,uBAAuB,CAAC,CAAC;gBAC9D,MAAM,eAAe,GAAG,uBAAuB,CAAC,KAAK,CACjD,SAAS,CACG,CAAC;gBACjB,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;gBAC5C,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;oBAC5B,MAAM,IAAI,CAAC,oBAAoB,CAAC,iBAAiB,CAC7C,uBAAuB,EACvB,SAAS,EACT,eAAe,CAClB,CAAC;gBACN,CAAC;YACL,CAAC;QACL,CAAC;aAAM,CAAC;YACJ,kDAAkD;YAClD,MAAM,mBAAmB,GAAG,IAAA,SAAM,GAAE,CAAC;YACrC,MAAM,sBAAsB,GAAG,IAAI,yBAAsB,CAAC;gBACtD,OAAO,EAAE,IAAA,SAAM,GAAE;gBACjB,MAAM,EAAE,mBAAmB;gBAC3B,WAAW,EAAE,KAAK,CAAC,iBAAiB;gBACpC,WAAW,EAAE,KAAK,CAAC,iBAAiB;gBACpC,KAAK,EAAE,KAAK,CAAC,WAAW;gBACxB,SAAS,EAAE,IAAI,IAAI,EAAE;gBACrB,SAAS,EAAE,KAAK,CAAC,MAAM;gBACvB,QAAQ,EAAE,mBAAmB;gBAC7B,OAAO,EAAE,CAAC;gBACV,eAAe,EAAE,IAAI;aACxB,CAAC,CAAC;YACH,MAAM,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,sBAAsB,CAAC,CAAC;YAC3D,MAAM,eAAe,GAAG,sBAAsB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAChE,MAAM,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAEhD,mCAAmC;YACnC,MAAM,kBAAkB,GAAG,IAAI,gBAAa,CAAC;gBACzC,OAAO,EAAE,IAAA,SAAM,GAAE;gBACjB,MAAM,EAAE,KAAK,CAAC,MAAM;gBACpB,QAAQ,EAAE,mBAAmB;gBAC7B,SAAS,EAAE,IAAI,IAAI,EAAE;gBACrB,SAAS,EAAE,KAAK,CAAC,MAAM;gBACvB,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,OAAO,EAAE,YAAY,CAAC,OAAO,GAAG,CAAC;gBACjC,eAAe,EAAE,IAAI;aACxB,CAAC,CAAC;YACH,MAAM,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC;YACzD,MAAM,sBAAsB,GAAG,kBAAkB,CAAC,KAAK,CACnD,YAAY,CACA,CAAC;YACjB,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;YAEnD,oDAAoD;YACpD,MAAM,WAAW,GACb,MAAM,IAAI,CAAC,cAAc,CAAC,gCAAgC,CACtD,KAAK,CAAC,MAAM,CACf,CAAC;YACN,IAAI,WAAW,EAAE,CAAC;gBACd,MAAM,gBAAgB,GAAG,WAAwB,CAAC;gBAClD,MAAM,uBAAuB,GAAG,IAAI,gBAAa,CAAC;oBAC9C,OAAO,EAAE,IAAA,SAAM,GAAE;oBACjB,MAAM,EAAE,mBAAmB;oBAC3B,WAAW,EAAE,gBAAgB,CAAC,KAAK;oBACnC,iBAAiB,EAAE,gBAAgB,CAAC,WAAW;oBAC/C,iBAAiB,EAAE,gBAAgB,CAAC,WAAW;oBAC/C,QAAQ,EAAE,KAAK,CAAC,MAAM;oBACtB,OAAO,EAAE,KAAK,CAAC,OAAO;oBACtB,SAAS,EAAE,IAAI,IAAI,EAAE;oBACrB,SAAS,EAAE,mBAAmB;oBAC9B,QAAQ,EAAE,IAAA,SAAM,GAAE;oBAClB,OAAO,EAAE,CAAC;oBACV,eAAe,EAAE,IAAI;iBACxB,CAAC,CAAC;gBACH,MAAM,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,uBAAuB,CAAC,CAAC;gBAC9D,MAAM,eAAe,GAAG,uBAAuB,CAAC,KAAK,CACjD,SAAS,CACG,CAAC;gBACjB,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;gBAC5C,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;oBAC5B,MAAM,IAAI,CAAC,oBAAoB,CAAC,iBAAiB,CAC7C,uBAAuB,EACvB,SAAS,EACT,eAAe,CAClB,CAAC;gBACN,CAAC;YACL,CAAC;QACL,CAAC;IACL,CAAC;CACJ;AArYD,gDAqYC"}
|
|
@@ -11,6 +11,7 @@ export declare class TransactionEventHandler extends BaseEventHandler<Transactio
|
|
|
11
11
|
handleClientEventFromRemoteListener(event: TransactionEvent): Promise<void>;
|
|
12
12
|
handleClientEventsFromRemoteListenerBulk(events: TransactionEvent[]): Promise<void>;
|
|
13
13
|
handleEvent(event: TransactionEvent, context?: import("./common/LoggingContext").LoggingContext): Promise<TransactionModel>;
|
|
14
|
+
private _handleEventWithRetryCheck;
|
|
14
15
|
private createMirrorEvent;
|
|
15
16
|
}
|
|
16
17
|
//# sourceMappingURL=TransactionEventHandler.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TransactionEventHandler.d.ts","sourceRoot":"","sources":["../src/TransactionEventHandler.ts"],"names":[],"mappings":"AAAA,OAAO,EASH,gBAAgB,EAChB,qBAAqB,EACrB,gBAAgB,EAChB,qBAAqB,EACxB,MAAM,GAAG,CAAC;AACX,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAM9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"TransactionEventHandler.d.ts","sourceRoot":"","sources":["../src/TransactionEventHandler.ts"],"names":[],"mappings":"AAAA,OAAO,EASH,gBAAgB,EAChB,qBAAqB,EACrB,gBAAgB,EAChB,qBAAqB,EACxB,MAAM,GAAG,CAAC;AACX,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAM9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAI1D,qBAAa,uBAAwB,SAAQ,gBAAgB,CAAC,gBAAgB,CAAC;IAEvE,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,UAAU;IAGlB,OAAO,CAAC,oBAAoB,CAAC;gBAJrB,UAAU,EAAE,qBAAqB,EACjC,UAAU,EAAE,qBAAqB,EACzC,QAAQ,EAAE,OAAO,EACjB,kBAAkB,CAAC,EAAE,kBAAkB,EAC/B,oBAAoB,CAAC,EAAE,oBAAoB,YAAA;IAKhD,aAAa,IAAI,qBAAqB;IAIhC,mCAAmC,CAC5C,KAAK,EAAE,gBAAgB,GACxB,OAAO,CAAC,IAAI,CAAC;IAWH,wCAAwC,CACjD,MAAM,EAAE,gBAAgB,EAAE,GAC3B,OAAO,CAAC,IAAI,CAAC;IAqBV,WAAW,CACb,KAAK,EAAE,gBAAgB,EACvB,OAAO,CAAC,EAAE,OAAO,yBAAyB,EAAE,cAAc,GAC3D,OAAO,CAAC,gBAAgB,CAAC;YAqBd,0BAA0B;YAiH1B,iBAAiB;CA0MlC"}
|
|
@@ -5,6 +5,8 @@ const _1 = require(".");
|
|
|
5
5
|
const BaseEventHandler_1 = require("./BaseEventHandler");
|
|
6
6
|
const splitTypeUtils_1 = require("./utils/splitTypeUtils");
|
|
7
7
|
const uuid_1 = require("uuid");
|
|
8
|
+
const tryLater_1 = require("./utils/tryLater");
|
|
9
|
+
const RetryError_1 = require("./errors/RetryError");
|
|
8
10
|
class TransactionEventHandler extends BaseEventHandler_1.BaseEventHandler {
|
|
9
11
|
constructor(modelStore, eventStore, isClient, modelChangeEmitter, activityEventHandler) {
|
|
10
12
|
super(isClient, modelChangeEmitter);
|
|
@@ -40,6 +42,21 @@ class TransactionEventHandler extends BaseEventHandler_1.BaseEventHandler {
|
|
|
40
42
|
}
|
|
41
43
|
}
|
|
42
44
|
async handleEvent(event, context) {
|
|
45
|
+
const maxRetries = 3;
|
|
46
|
+
for (let attempt = 1; attempt <= maxRetries; attempt++) {
|
|
47
|
+
try {
|
|
48
|
+
return await this._handleEventWithRetryCheck(event, context, attempt);
|
|
49
|
+
}
|
|
50
|
+
catch (error) {
|
|
51
|
+
if (error instanceof RetryError_1.RetryError && attempt < maxRetries) {
|
|
52
|
+
continue;
|
|
53
|
+
}
|
|
54
|
+
throw error;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
throw new Error("Max retries exhausted");
|
|
58
|
+
}
|
|
59
|
+
async _handleEventWithRetryCheck(event, context, attempt) {
|
|
43
60
|
const eventType = event.constructor.name;
|
|
44
61
|
const logData = {
|
|
45
62
|
requestId: context?.requestId,
|
|
@@ -48,6 +65,7 @@ class TransactionEventHandler extends BaseEventHandler_1.BaseEventHandler {
|
|
|
48
65
|
version: event.version,
|
|
49
66
|
eventId: event.eventId,
|
|
50
67
|
userId: event.userId,
|
|
68
|
+
attempt,
|
|
51
69
|
};
|
|
52
70
|
context?.logger?.info("[TransactionEventHandler] Starting event processing", logData);
|
|
53
71
|
const existingModel = await this.modelStore.getByStreamIdWhereDeletedIsFalse(event.streamId);
|
|
@@ -57,39 +75,52 @@ class TransactionEventHandler extends BaseEventHandler_1.BaseEventHandler {
|
|
|
57
75
|
existingModelVersion: existingModel?.version,
|
|
58
76
|
});
|
|
59
77
|
const model = event.apply(existingModel);
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
newModelVersion: model.version,
|
|
63
|
-
shouldSkipSave: this.shouldSkipSave(existingModel, model),
|
|
64
|
-
});
|
|
65
|
-
if (!this.shouldSkipSave(existingModel, model)) {
|
|
66
|
-
await this.modelStore.save(model);
|
|
67
|
-
context?.logger?.info("[TransactionEventHandler] Model saved successfully", {
|
|
78
|
+
if (this.shouldSkipSave(existingModel, model)) {
|
|
79
|
+
context?.logger?.warn("[TransactionEventHandler] Skipping outdated event", {
|
|
68
80
|
...logData,
|
|
69
|
-
|
|
70
|
-
|
|
81
|
+
existingVersion: existingModel?.version,
|
|
82
|
+
eventVersion: model.version,
|
|
71
83
|
});
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
84
|
+
return model;
|
|
85
|
+
}
|
|
86
|
+
const retryCheck = this.shouldTryLater(existingModel, model);
|
|
87
|
+
if (retryCheck.shouldRetry) {
|
|
88
|
+
context?.logger?.info("[TransactionEventHandler] Version gap detected", {
|
|
89
|
+
...logData,
|
|
90
|
+
existingVersion: existingModel?.version,
|
|
91
|
+
eventVersion: model.version,
|
|
92
|
+
versionGap: retryCheck.versionGap,
|
|
93
|
+
delayMs: retryCheck.delayMs,
|
|
94
|
+
});
|
|
95
|
+
await (0, tryLater_1.tryLater)({
|
|
96
|
+
shouldRetry: true,
|
|
97
|
+
delayMs: retryCheck.delayMs,
|
|
98
|
+
versionGap: retryCheck.versionGap,
|
|
99
|
+
maxRetries: 3,
|
|
100
|
+
currentAttempt: attempt,
|
|
101
|
+
context,
|
|
102
|
+
logContext: logData,
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
await this.modelStore.save(model);
|
|
106
|
+
context?.logger?.info("[TransactionEventHandler] Model saved successfully", {
|
|
107
|
+
...logData,
|
|
108
|
+
modelVersion: model.version,
|
|
109
|
+
isClient: this.isClient,
|
|
110
|
+
});
|
|
111
|
+
if (this.isClient) {
|
|
112
|
+
await this.eventStore.addEvent(event);
|
|
113
|
+
this.modelChangeEmitter?.emit("TransactionModel", model);
|
|
114
|
+
if (this.activityEventHandler) {
|
|
115
|
+
await this.activityEventHandler.createActivityLog(event, existingModel, model);
|
|
85
116
|
}
|
|
86
117
|
}
|
|
87
118
|
else {
|
|
88
|
-
context?.logger?.
|
|
119
|
+
context?.logger?.info("[TransactionEventHandler] Creating mirror event", {
|
|
89
120
|
...logData,
|
|
90
|
-
|
|
91
|
-
newVersion: model.version,
|
|
121
|
+
recipientUserId: model.recipientUserId,
|
|
92
122
|
});
|
|
123
|
+
await this.createMirrorEvent(event, model, context);
|
|
93
124
|
}
|
|
94
125
|
context?.logger?.info("[TransactionEventHandler] Event processing completed", logData);
|
|
95
126
|
return model;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TransactionEventHandler.js","sourceRoot":"","sources":["../src/TransactionEventHandler.ts"],"names":[],"mappings":";;;AAAA,wBAaW;AACX,yDAAsD;AAEtD,2DAGgC;AAChC,+BAAoC;
|
|
1
|
+
{"version":3,"file":"TransactionEventHandler.js","sourceRoot":"","sources":["../src/TransactionEventHandler.ts"],"names":[],"mappings":"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"}
|
|
@@ -11,6 +11,7 @@ export declare class UserEventHandler extends BaseEventHandler<UserEvent> {
|
|
|
11
11
|
handleClientEventFromRemoteListener(event: UserEvent): Promise<void>;
|
|
12
12
|
handleClientEventsFromRemoteListenerBulk(events: UserEvent[]): Promise<void>;
|
|
13
13
|
handleEvent(event: UserEvent, context?: import("./common/LoggingContext").LoggingContext): Promise<UserModel>;
|
|
14
|
+
private _handleEventWithRetryCheck;
|
|
14
15
|
handleUserCreatedBackend(event: UserCreated): Promise<UserModel>;
|
|
15
16
|
}
|
|
16
17
|
//# sourceMappingURL=UserEventHandler.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UserEventHandler.d.ts","sourceRoot":"","sources":["../src/UserEventHandler.ts"],"names":[],"mappings":"AAAA,OAAO,EAGH,WAAW,EACX,SAAS,EACT,cAAc,EACd,SAAS,EACT,cAAc,EACjB,MAAM,GAAG,CAAC;AACX,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAE9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"UserEventHandler.d.ts","sourceRoot":"","sources":["../src/UserEventHandler.ts"],"names":[],"mappings":"AAAA,OAAO,EAGH,WAAW,EACX,SAAS,EACT,cAAc,EACd,SAAS,EACT,cAAc,EACjB,MAAM,GAAG,CAAC;AACX,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAE9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAI1D,qBAAa,gBAAiB,SAAQ,gBAAgB,CAAC,SAAS,CAAC;IAEzD,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,UAAU;IAGlB,OAAO,CAAC,oBAAoB,CAAC;gBAJrB,UAAU,EAAE,cAAc,EAC1B,UAAU,EAAE,cAAc,EAClC,QAAQ,EAAE,OAAO,EACjB,kBAAkB,CAAC,EAAE,kBAAkB,EAC/B,oBAAoB,CAAC,EAAE,oBAAoB,YAAA;IAKhD,aAAa,IAAI,cAAc;IAIzB,mCAAmC,CAC5C,KAAK,EAAE,SAAS,GACjB,OAAO,CAAC,IAAI,CAAC;IAWH,wCAAwC,CACjD,MAAM,EAAE,SAAS,EAAE,GACpB,OAAO,CAAC,IAAI,CAAC;IAqBV,WAAW,CACb,KAAK,EAAE,SAAS,EAChB,OAAO,CAAC,EAAE,OAAO,yBAAyB,EAAE,cAAc,GAC3D,OAAO,CAAC,SAAS,CAAC;YA2BP,0BAA0B;IAyDlC,wBAAwB,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,SAAS,CAAC;CAuDzE"}
|
package/dist/UserEventHandler.js
CHANGED
|
@@ -4,6 +4,8 @@ exports.UserEventHandler = void 0;
|
|
|
4
4
|
const _1 = require(".");
|
|
5
5
|
const BaseEventHandler_1 = require("./BaseEventHandler");
|
|
6
6
|
const uuid_1 = require("uuid");
|
|
7
|
+
const tryLater_1 = require("./utils/tryLater");
|
|
8
|
+
const RetryError_1 = require("./errors/RetryError");
|
|
7
9
|
class UserEventHandler extends BaseEventHandler_1.BaseEventHandler {
|
|
8
10
|
constructor(modelStore, eventStore, isClient, modelChangeEmitter, activityEventHandler) {
|
|
9
11
|
super(isClient, modelChangeEmitter);
|
|
@@ -44,20 +46,61 @@ class UserEventHandler extends BaseEventHandler_1.BaseEventHandler {
|
|
|
44
46
|
return await this.handleUserCreatedBackend(event);
|
|
45
47
|
}
|
|
46
48
|
else {
|
|
47
|
-
const
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
await this.activityEventHandler.createActivityLog(event, existingModel, updatedModel);
|
|
49
|
+
const maxRetries = 3;
|
|
50
|
+
for (let attempt = 1; attempt <= maxRetries; attempt++) {
|
|
51
|
+
try {
|
|
52
|
+
return await this._handleEventWithRetryCheck(event, context, attempt);
|
|
53
|
+
}
|
|
54
|
+
catch (error) {
|
|
55
|
+
if (error instanceof RetryError_1.RetryError && attempt < maxRetries) {
|
|
56
|
+
continue;
|
|
56
57
|
}
|
|
58
|
+
throw error;
|
|
57
59
|
}
|
|
58
60
|
}
|
|
61
|
+
throw new Error("Max retries exhausted");
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
async _handleEventWithRetryCheck(event, context, attempt) {
|
|
65
|
+
const existingModel = await this.modelStore.getByStreamIdWhereDeletedIsFalse(event.streamId);
|
|
66
|
+
const updatedModel = event.apply(existingModel);
|
|
67
|
+
if (this.shouldSkipSave(existingModel, updatedModel)) {
|
|
59
68
|
return updatedModel;
|
|
60
69
|
}
|
|
70
|
+
const retryCheck = this.shouldTryLater(existingModel, updatedModel);
|
|
71
|
+
if (retryCheck.shouldRetry) {
|
|
72
|
+
context?.logger?.info("[UserEventHandler] Version gap detected", {
|
|
73
|
+
requestId: context?.requestId,
|
|
74
|
+
eventType: event.constructor.name,
|
|
75
|
+
streamId: event.streamId,
|
|
76
|
+
existingVersion: existingModel?.version,
|
|
77
|
+
eventVersion: updatedModel.version,
|
|
78
|
+
versionGap: retryCheck.versionGap,
|
|
79
|
+
delayMs: retryCheck.delayMs,
|
|
80
|
+
attempt,
|
|
81
|
+
});
|
|
82
|
+
await (0, tryLater_1.tryLater)({
|
|
83
|
+
shouldRetry: true,
|
|
84
|
+
delayMs: retryCheck.delayMs,
|
|
85
|
+
versionGap: retryCheck.versionGap,
|
|
86
|
+
maxRetries: 3,
|
|
87
|
+
currentAttempt: attempt,
|
|
88
|
+
context,
|
|
89
|
+
logContext: {
|
|
90
|
+
eventType: event.constructor.name,
|
|
91
|
+
streamId: event.streamId,
|
|
92
|
+
},
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
await this.modelStore.save(updatedModel);
|
|
96
|
+
if (this.isClient) {
|
|
97
|
+
await this.eventStore.addEvent(event);
|
|
98
|
+
this.modelChangeEmitter?.emit("UserModel", updatedModel);
|
|
99
|
+
if (this.activityEventHandler) {
|
|
100
|
+
await this.activityEventHandler.createActivityLog(event, existingModel, updatedModel);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
return updatedModel;
|
|
61
104
|
}
|
|
62
105
|
async handleUserCreatedBackend(event) {
|
|
63
106
|
if (this.isClient) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UserEventHandler.js","sourceRoot":"","sources":["../src/UserEventHandler.ts"],"names":[],"mappings":";;;AAAA,wBAQW;AACX,yDAAsD;AAEtD,+BAAoC;
|
|
1
|
+
{"version":3,"file":"UserEventHandler.js","sourceRoot":"","sources":["../src/UserEventHandler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export declare class RetryError extends Error {
|
|
2
|
+
readonly versionGap?: number | undefined;
|
|
3
|
+
readonly delayMs?: number | undefined;
|
|
4
|
+
constructor(message: string, versionGap?: number | undefined, delayMs?: number | undefined);
|
|
5
|
+
}
|
|
6
|
+
//# sourceMappingURL=RetryError.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RetryError.d.ts","sourceRoot":"","sources":["../../src/errors/RetryError.ts"],"names":[],"mappings":"AAAA,qBAAa,UAAW,SAAQ,KAAK;aAGb,UAAU,CAAC,EAAE,MAAM;aACnB,OAAO,CAAC,EAAE,MAAM;gBAFhC,OAAO,EAAE,MAAM,EACC,UAAU,CAAC,EAAE,MAAM,YAAA,EACnB,OAAO,CAAC,EAAE,MAAM,YAAA;CAKvC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RetryError = void 0;
|
|
4
|
+
class RetryError extends Error {
|
|
5
|
+
constructor(message, versionGap, delayMs) {
|
|
6
|
+
super(message);
|
|
7
|
+
this.versionGap = versionGap;
|
|
8
|
+
this.delayMs = delayMs;
|
|
9
|
+
this.name = "RetryError";
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
exports.RetryError = RetryError;
|
|
13
|
+
//# sourceMappingURL=RetryError.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RetryError.js","sourceRoot":"","sources":["../../src/errors/RetryError.ts"],"names":[],"mappings":";;;AAAA,MAAa,UAAW,SAAQ,KAAK;IACjC,YACI,OAAe,EACC,UAAmB,EACnB,OAAgB;QAEhC,KAAK,CAAC,OAAO,CAAC,CAAC;QAHC,eAAU,GAAV,UAAU,CAAS;QACnB,YAAO,GAAP,OAAO,CAAS;QAGhC,IAAI,CAAC,IAAI,GAAG,YAAY,CAAC;IAC7B,CAAC;CACJ;AATD,gCASC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
export * from "./events";
|
|
2
2
|
export { BaseEventHandler } from "./BaseEventHandler";
|
|
3
3
|
export type { LoggingContext } from "./common/LoggingContext";
|
|
4
|
+
export { RetryError } from "./errors/RetryError";
|
|
5
|
+
export { tryLater } from "./utils/tryLater";
|
|
6
|
+
export type { TryLaterOptions } from "./utils/tryLater";
|
|
4
7
|
export { TransactionEvent, UserEvent, FriendEvent, GroupEvent, GroupTransactionEvent, ActivityLogEvent, } from "./common/DomainEvents";
|
|
5
8
|
export { UserController } from "./client/controllers/UserController";
|
|
6
9
|
export { FriendController } from "./client/controllers/FriendController";
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,cAAc,UAAU,CAAC;AAGzB,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAGtD,YAAY,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAG9D,OAAO,EACH,gBAAgB,EAChB,SAAS,EACT,WAAW,EACX,UAAU,EACV,qBAAqB,EACrB,gBAAgB,GACnB,MAAM,uBAAuB,CAAC;AAG/B,OAAO,EAAE,cAAc,EAAE,MAAM,qCAAqC,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,uCAAuC,CAAC;AACzE,OAAO,EAAE,qBAAqB,EAAE,MAAM,4CAA4C,CAAC;AAGnF,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAGlE,OAAO,EACH,iBAAiB,EACjB,aAAa,EACb,iBAAiB,EACjB,mBAAmB,EACnB,wBAAwB,EACxB,iBAAiB,EACjB,mBAAmB,EACnB,qBAAqB,EACrB,0BAA0B,EAC1B,oBAAoB,EACpB,+BAA+B,EAC/B,uBAAuB,EACvB,kBAAkB,EAClB,gBAAgB,EAChB,wBAAwB,EACxB,gBAAgB,EAChB,gBAAgB,EAChB,gBAAgB,EAChB,WAAW,GACd,MAAM,qBAAqB,CAAC;AAG7B,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAGvE,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAG7D,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,YAAY,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAG1D,YAAY,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACtE,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,cAAc,UAAU,CAAC;AAGzB,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAGtD,YAAY,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAG9D,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,YAAY,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAGxD,OAAO,EACH,gBAAgB,EAChB,SAAS,EACT,WAAW,EACX,UAAU,EACV,qBAAqB,EACrB,gBAAgB,GACnB,MAAM,uBAAuB,CAAC;AAG/B,OAAO,EAAE,cAAc,EAAE,MAAM,qCAAqC,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,uCAAuC,CAAC;AACzE,OAAO,EAAE,qBAAqB,EAAE,MAAM,4CAA4C,CAAC;AAGnF,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAGlE,OAAO,EACH,iBAAiB,EACjB,aAAa,EACb,iBAAiB,EACjB,mBAAmB,EACnB,wBAAwB,EACxB,iBAAiB,EACjB,mBAAmB,EACnB,qBAAqB,EACrB,0BAA0B,EAC1B,oBAAoB,EACpB,+BAA+B,EAC/B,uBAAuB,EACvB,kBAAkB,EAClB,gBAAgB,EAChB,wBAAwB,EACxB,gBAAgB,EAChB,gBAAgB,EAChB,gBAAgB,EAChB,WAAW,GACd,MAAM,qBAAqB,CAAC;AAG7B,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAGvE,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAG7D,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,YAAY,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAG1D,YAAY,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACtE,OAAO,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAGpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -14,12 +14,17 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
15
|
};
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.__resetSDKForTesting = exports.EventConverterFactory = exports.CurrencyStore = exports.ModelChangeEmitter = exports.isSDKInitialized = exports.firestoreToEvent = exports.eventToFirestore = exports.getModelChangeObservable = exports.getCurrencyStore = exports.getFirebaseAdapter = exports.getActivityEventHandler = exports.getGroupTransactionEventHandler = exports.getGroupEventHandler = exports.getTransactionEventHandler = exports.getFriendEventHandler = exports.getUserEventHandler = exports.getUIEventHandler = exports.getTransactionController = exports.getFriendController = exports.getUserController = exports.initializeSDK = exports.EventProcessorSDK = exports.UIEventHandler = exports.TransactionController = exports.FriendController = exports.UserController = exports.BaseEventHandler = void 0;
|
|
17
|
+
exports.__resetSDKForTesting = exports.EventConverterFactory = exports.CurrencyStore = exports.ModelChangeEmitter = exports.isSDKInitialized = exports.firestoreToEvent = exports.eventToFirestore = exports.getModelChangeObservable = exports.getCurrencyStore = exports.getFirebaseAdapter = exports.getActivityEventHandler = exports.getGroupTransactionEventHandler = exports.getGroupEventHandler = exports.getTransactionEventHandler = exports.getFriendEventHandler = exports.getUserEventHandler = exports.getUIEventHandler = exports.getTransactionController = exports.getFriendController = exports.getUserController = exports.initializeSDK = exports.EventProcessorSDK = exports.UIEventHandler = exports.TransactionController = exports.FriendController = exports.UserController = exports.tryLater = exports.RetryError = exports.BaseEventHandler = void 0;
|
|
18
18
|
// Export all backend event definitions here
|
|
19
19
|
__exportStar(require("./events"), exports);
|
|
20
20
|
// Export base event handler interface
|
|
21
21
|
var BaseEventHandler_1 = require("./BaseEventHandler");
|
|
22
22
|
Object.defineProperty(exports, "BaseEventHandler", { enumerable: true, get: function () { return BaseEventHandler_1.BaseEventHandler; } });
|
|
23
|
+
// Export retry utilities
|
|
24
|
+
var RetryError_1 = require("./errors/RetryError");
|
|
25
|
+
Object.defineProperty(exports, "RetryError", { enumerable: true, get: function () { return RetryError_1.RetryError; } });
|
|
26
|
+
var tryLater_1 = require("./utils/tryLater");
|
|
27
|
+
Object.defineProperty(exports, "tryLater", { enumerable: true, get: function () { return tryLater_1.tryLater; } });
|
|
23
28
|
// Export controllers
|
|
24
29
|
var UserController_1 = require("./client/controllers/UserController");
|
|
25
30
|
Object.defineProperty(exports, "UserController", { enumerable: true, get: function () { return UserController_1.UserController; } });
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,4CAA4C;AAC5C,2CAAyB;AAEzB,sCAAsC;AACtC,uDAAsD;AAA7C,oHAAA,gBAAgB,OAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,4CAA4C;AAC5C,2CAAyB;AAEzB,sCAAsC;AACtC,uDAAsD;AAA7C,oHAAA,gBAAgB,OAAA;AAKzB,yBAAyB;AACzB,kDAAiD;AAAxC,wGAAA,UAAU,OAAA;AACnB,6CAA4C;AAAnC,oGAAA,QAAQ,OAAA;AAajB,qBAAqB;AACrB,sEAAqE;AAA5D,gHAAA,cAAc,OAAA;AACvB,0EAAyE;AAAhE,oHAAA,gBAAgB,OAAA;AACzB,oFAAmF;AAA1E,8HAAA,qBAAqB,OAAA;AAE9B,yBAAyB;AACzB,mEAAkE;AAAzD,gHAAA,cAAc,OAAA;AAEvB,4BAA4B;AAC5B,yDAoB6B;AAnBzB,sHAAA,iBAAiB,OAAA;AACjB,kHAAA,aAAa,OAAA;AACb,sHAAA,iBAAiB,OAAA;AACjB,wHAAA,mBAAmB,OAAA;AACnB,6HAAA,wBAAwB,OAAA;AACxB,sHAAA,iBAAiB,OAAA;AACjB,wHAAA,mBAAmB,OAAA;AACnB,0HAAA,qBAAqB,OAAA;AACrB,+HAAA,0BAA0B,OAAA;AAC1B,yHAAA,oBAAoB,OAAA;AACpB,oIAAA,+BAA+B,OAAA;AAC/B,4HAAA,uBAAuB,OAAA;AACvB,uHAAA,kBAAkB,OAAA;AAClB,qHAAA,gBAAgB,OAAA;AAChB,6HAAA,wBAAwB,OAAA;AACxB,qHAAA,gBAAgB,OAAA;AAChB,qHAAA,gBAAgB,OAAA;AAChB,qHAAA,gBAAgB,OAAA;AAIpB,4BAA4B;AAC5B,2DAAuE;AAA9D,wHAAA,kBAAkB,OAAA;AAK3B,kCAAkC;AAClC,uDAAsD;AAA7C,8GAAA,aAAa,OAAA;AAKtB,8DAAoE;AAA3D,uHAAA,qBAAqB,OAAA;AAE9B,yCAAyC;AACzC,yDAA2D;AAAlD,yHAAA,oBAAoB,OAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { LoggingContext } from "../common/LoggingContext";
|
|
2
|
+
export interface TryLaterOptions {
|
|
3
|
+
shouldRetry: boolean;
|
|
4
|
+
delayMs: number;
|
|
5
|
+
versionGap: number;
|
|
6
|
+
maxRetries: number;
|
|
7
|
+
currentAttempt: number;
|
|
8
|
+
context?: LoggingContext;
|
|
9
|
+
logContext?: Record<string, any>;
|
|
10
|
+
}
|
|
11
|
+
export declare function tryLater(options: TryLaterOptions): Promise<void>;
|
|
12
|
+
//# sourceMappingURL=tryLater.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tryLater.d.ts","sourceRoot":"","sources":["../../src/utils/tryLater.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAM1D,MAAM,WAAW,eAAe;IAC5B,WAAW,EAAE,OAAO,CAAC;IACrB,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,cAAc,EAAE,MAAM,CAAC;IACvB,OAAO,CAAC,EAAE,cAAc,CAAC;IACzB,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CACpC;AAED,wBAAsB,QAAQ,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,CA6BtE"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.tryLater = tryLater;
|
|
4
|
+
const RetryError_1 = require("../errors/RetryError");
|
|
5
|
+
function delay(ms) {
|
|
6
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
7
|
+
}
|
|
8
|
+
async function tryLater(options) {
|
|
9
|
+
if (!options.shouldRetry) {
|
|
10
|
+
return;
|
|
11
|
+
}
|
|
12
|
+
if (options.currentAttempt >= options.maxRetries) {
|
|
13
|
+
throw new Error(`Max retries (${options.maxRetries}) exhausted for version gap of ${options.versionGap}`);
|
|
14
|
+
}
|
|
15
|
+
const delayMs = options.currentAttempt === 1 ? options.delayMs : 50;
|
|
16
|
+
options.context?.logger?.info("[tryLater] Retrying after adaptive delay", {
|
|
17
|
+
...options.logContext,
|
|
18
|
+
requestId: options.context?.requestId,
|
|
19
|
+
attempt: options.currentAttempt,
|
|
20
|
+
delayMs,
|
|
21
|
+
versionGap: options.versionGap,
|
|
22
|
+
adaptiveDelay: options.currentAttempt === 1,
|
|
23
|
+
});
|
|
24
|
+
await delay(delayMs);
|
|
25
|
+
throw new RetryError_1.RetryError("Version gap detected, retrying", options.versionGap, delayMs);
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=tryLater.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tryLater.js","sourceRoot":"","sources":["../../src/utils/tryLater.ts"],"names":[],"mappings":";;AAiBA,4BA6BC;AA9CD,qDAAkD;AAGlD,SAAS,KAAK,CAAC,EAAU;IACrB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;AAC7D,CAAC;AAYM,KAAK,UAAU,QAAQ,CAAC,OAAwB;IACnD,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;QACvB,OAAO;IACX,CAAC;IAED,IAAI,OAAO,CAAC,cAAc,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;QAC/C,MAAM,IAAI,KAAK,CACX,gBAAgB,OAAO,CAAC,UAAU,kCAAkC,OAAO,CAAC,UAAU,EAAE,CAC3F,CAAC;IACN,CAAC;IAED,MAAM,OAAO,GACT,OAAO,CAAC,cAAc,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;IAExD,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,0CAA0C,EAAE;QACtE,GAAG,OAAO,CAAC,UAAU;QACrB,SAAS,EAAE,OAAO,CAAC,OAAO,EAAE,SAAS;QACrC,OAAO,EAAE,OAAO,CAAC,cAAc;QAC/B,OAAO;QACP,UAAU,EAAE,OAAO,CAAC,UAAU;QAC9B,aAAa,EAAE,OAAO,CAAC,cAAc,KAAK,CAAC;KAC9C,CAAC,CAAC;IAEH,MAAM,KAAK,CAAC,OAAO,CAAC,CAAC;IACrB,MAAM,IAAI,uBAAU,CAChB,gCAAgC,EAChC,OAAO,CAAC,UAAU,EAClB,OAAO,CACV,CAAC;AACN,CAAC"}
|