@zeeshan60/event-processor 1.0.11 → 1.0.13
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/ActivityEventHandler.d.ts +4 -4
- package/dist/ActivityEventHandler.d.ts.map +1 -1
- package/dist/ActivityLogEvents.d.ts +4 -2
- package/dist/ActivityLogEvents.d.ts.map +1 -1
- package/dist/ActivityLogEvents.js +1 -0
- package/dist/EventProcessorSDK.d.ts +22 -18
- package/dist/EventProcessorSDK.d.ts.map +1 -1
- package/dist/EventProcessorSDK.js +15 -4
- package/dist/FriendEventHandler.d.ts +4 -12
- package/dist/FriendEventHandler.d.ts.map +1 -1
- package/dist/FriendEventHandler.js +22 -54
- package/dist/FriendEvents.d.ts +13 -3
- package/dist/FriendEvents.d.ts.map +1 -1
- package/dist/FriendEvents.js +16 -7
- package/dist/GroupEventHandler.d.ts +7 -7
- package/dist/GroupEventHandler.d.ts.map +1 -1
- package/dist/GroupEventHandler.js +21 -12
- package/dist/GroupEvents.d.ts +15 -3
- package/dist/GroupEvents.d.ts.map +1 -1
- package/dist/GroupEvents.js +25 -13
- package/dist/GroupTransactionEventHandler.d.ts +7 -7
- package/dist/GroupTransactionEventHandler.d.ts.map +1 -1
- package/dist/GroupTransactionEventHandler.js +23 -16
- package/dist/GroupTransactionEvents.d.ts +22 -4
- package/dist/GroupTransactionEvents.d.ts.map +1 -1
- package/dist/GroupTransactionEvents.js +39 -21
- package/dist/TransactionEventHandler.d.ts +2 -5
- package/dist/TransactionEventHandler.d.ts.map +1 -1
- package/dist/TransactionEventHandler.js +29 -13
- package/dist/TransactionEvents.d.ts +24 -8
- package/dist/TransactionEvents.d.ts.map +1 -1
- package/dist/TransactionEvents.js +38 -22
- package/dist/UserEventHandler.d.ts +3 -11
- package/dist/UserEventHandler.d.ts.map +1 -1
- package/dist/UserEventHandler.js +64 -62
- package/dist/UserEvents.d.ts +20 -3
- package/dist/UserEvents.d.ts.map +1 -1
- package/dist/UserEvents.js +53 -18
- package/dist/__tests__/e2e/setup/firebaseEmulator.d.ts +3 -0
- package/dist/__tests__/e2e/setup/firebaseEmulator.d.ts.map +1 -0
- package/dist/__tests__/e2e/setup/firebaseEmulator.js +87 -0
- package/dist/__tests__/e2e/setup/firestoreStores.d.ts +28 -0
- package/dist/__tests__/e2e/setup/firestoreStores.d.ts.map +1 -0
- package/dist/__tests__/e2e/setup/firestoreStores.js +276 -0
- package/dist/__tests__/e2e/setup/firestoreTestHelpers.d.ts +15 -0
- package/dist/__tests__/e2e/setup/firestoreTestHelpers.d.ts.map +1 -0
- package/dist/__tests__/e2e/setup/firestoreTestHelpers.js +167 -0
- package/dist/__tests__/test-helpers/IMActivityLogEventStore.d.ts +2 -2
- package/dist/__tests__/test-helpers/IMActivityLogEventStore.d.ts.map +1 -1
- package/dist/__tests__/test-helpers/IMActivityLogModelStore.d.ts +2 -2
- package/dist/__tests__/test-helpers/IMActivityLogModelStore.d.ts.map +1 -1
- package/dist/__tests__/test-helpers/IMFriendEventStore.d.ts +2 -2
- package/dist/__tests__/test-helpers/IMFriendEventStore.d.ts.map +1 -1
- package/dist/__tests__/test-helpers/IMFriendModelStore.d.ts +3 -2
- package/dist/__tests__/test-helpers/IMFriendModelStore.d.ts.map +1 -1
- package/dist/__tests__/test-helpers/IMFriendModelStore.js +9 -0
- package/dist/__tests__/test-helpers/IMGroupEventStore.d.ts +2 -2
- package/dist/__tests__/test-helpers/IMGroupEventStore.d.ts.map +1 -1
- package/dist/__tests__/test-helpers/IMGroupModelStore.d.ts +2 -2
- package/dist/__tests__/test-helpers/IMGroupModelStore.d.ts.map +1 -1
- package/dist/__tests__/test-helpers/IMGroupTransactionEventStore.d.ts +2 -2
- package/dist/__tests__/test-helpers/IMGroupTransactionEventStore.d.ts.map +1 -1
- package/dist/__tests__/test-helpers/IMGroupTransactionModelStore.d.ts +2 -2
- package/dist/__tests__/test-helpers/IMGroupTransactionModelStore.d.ts.map +1 -1
- package/dist/__tests__/test-helpers/IMTransactionEventStore.d.ts +2 -2
- package/dist/__tests__/test-helpers/IMTransactionEventStore.d.ts.map +1 -1
- package/dist/__tests__/test-helpers/IMTransactionModelStore.d.ts +2 -2
- package/dist/__tests__/test-helpers/IMTransactionModelStore.d.ts.map +1 -1
- package/dist/__tests__/test-helpers/IMUserEventStore.d.ts +2 -2
- package/dist/__tests__/test-helpers/IMUserEventStore.d.ts.map +1 -1
- package/dist/__tests__/test-helpers/IMUserModelStore.d.ts +2 -2
- package/dist/__tests__/test-helpers/IMUserModelStore.d.ts.map +1 -1
- package/dist/__tests__/test-helpers/MockFirebaseAdapter.d.ts +2 -1
- package/dist/__tests__/test-helpers/MockFirebaseAdapter.d.ts.map +1 -1
- package/dist/__tests__/test-helpers/MockFirebaseAdapter.js +5 -1
- package/dist/client/controllers/FriendController.d.ts +12 -0
- package/dist/client/controllers/FriendController.d.ts.map +1 -0
- package/dist/client/controllers/FriendController.js +122 -0
- package/dist/client/controllers/UserController.d.ts +6 -5
- package/dist/client/controllers/UserController.d.ts.map +1 -1
- package/dist/client/controllers/UserController.js +94 -7
- package/dist/client/handlers/UIEventHandler.d.ts +1 -1
- package/dist/client/handlers/UIEventHandler.d.ts.map +1 -1
- package/dist/client/handlers/UIEventHandler.js +4 -2
- package/dist/client/handlers/UIFriendEventHandler.d.ts +6 -6
- package/dist/client/handlers/UIFriendEventHandler.d.ts.map +1 -1
- package/dist/client/handlers/UIGroupEventHandler.d.ts +7 -7
- package/dist/client/handlers/UIGroupEventHandler.d.ts.map +1 -1
- package/dist/client/handlers/UIGroupTransactionEventHandler.d.ts +7 -7
- package/dist/client/handlers/UIGroupTransactionEventHandler.d.ts.map +1 -1
- package/dist/client/handlers/UITransactionEventHandler.d.ts +5 -5
- package/dist/client/handlers/UITransactionEventHandler.d.ts.map +1 -1
- package/dist/client/handlers/UIUserEventHandler.d.ts +4 -4
- package/dist/client/handlers/UIUserEventHandler.d.ts.map +1 -1
- package/dist/common/DomainEvents.d.ts +1 -1
- package/dist/common/DomainEvents.d.ts.map +1 -1
- package/dist/common/DomainEvents.js +37 -37
- package/dist/common/Event.d.ts +3 -2
- package/dist/common/Event.d.ts.map +1 -1
- package/dist/common/EventBus.d.ts +2 -2
- package/dist/common/EventBus.d.ts.map +1 -1
- package/dist/common/EventBusSingleton.d.ts +1 -1
- package/dist/common/Model.d.ts.map +1 -1
- package/dist/common/index.d.ts +2 -2
- package/dist/contracts/common/index.d.ts.map +1 -1
- package/dist/contracts/expenses/index.d.ts.map +1 -1
- package/dist/contracts/friends/index.d.ts.map +1 -1
- package/dist/contracts/groups/index.d.ts.map +1 -1
- package/dist/contracts/index.d.ts +1 -0
- package/dist/contracts/index.d.ts.map +1 -1
- package/dist/contracts/index.js +1 -0
- package/dist/contracts/shared/index.d.ts.map +1 -1
- package/dist/contracts/transactions/index.d.ts.map +1 -1
- package/dist/contracts/users/index.d.ts +15 -0
- package/dist/contracts/users/index.d.ts.map +1 -0
- package/dist/contracts/users/index.js +2 -0
- package/dist/converters/eventConverter.d.ts +3 -3
- package/dist/converters/eventConverter.d.ts.map +1 -1
- package/dist/converters/eventConverter.js +67 -50
- package/dist/events.d.ts +29 -29
- package/dist/events.d.ts.map +1 -1
- package/dist/index.d.ts +18 -14
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +10 -2
- package/dist/store/ActivityLogEventStore.d.ts +1 -1
- package/dist/store/ActivityLogEventStore.d.ts.map +1 -1
- package/dist/store/ActivityLogModelStore.d.ts +2 -2
- package/dist/store/ActivityLogModelStore.d.ts.map +1 -1
- package/dist/store/FriendEventStore.d.ts +1 -1
- package/dist/store/FriendEventStore.d.ts.map +1 -1
- package/dist/store/FriendModelStore.d.ts +3 -2
- package/dist/store/FriendModelStore.d.ts.map +1 -1
- package/dist/store/GroupEventStore.d.ts +1 -1
- package/dist/store/GroupEventStore.d.ts.map +1 -1
- package/dist/store/GroupModelStore.d.ts +2 -2
- package/dist/store/GroupModelStore.d.ts.map +1 -1
- package/dist/store/GroupTransactionEventStore.d.ts +1 -1
- package/dist/store/GroupTransactionEventStore.d.ts.map +1 -1
- package/dist/store/GroupTransactionModelStore.d.ts +2 -2
- package/dist/store/GroupTransactionModelStore.d.ts.map +1 -1
- package/dist/store/ModelStore.d.ts +1 -1
- package/dist/store/ModelStore.d.ts.map +1 -1
- package/dist/store/TransactionEventStore.d.ts +1 -1
- package/dist/store/TransactionEventStore.d.ts.map +1 -1
- package/dist/store/TransactionModelStore.d.ts +2 -2
- package/dist/store/TransactionModelStore.d.ts.map +1 -1
- package/dist/store/UserEventStore.d.ts +1 -1
- package/dist/store/UserEventStore.d.ts.map +1 -1
- package/dist/store/UserModelStore.d.ts +2 -2
- package/dist/store/UserModelStore.d.ts.map +1 -1
- package/dist/utils/splitTypeUtils.d.ts +1 -1
- package/dist/utils/splitTypeUtils.d.ts.map +1 -1
- package/dist/utils/userPathUtils.d.ts +1 -1
- package/dist/utils/userPathUtils.d.ts.map +1 -1
- package/dist/utils/userPathUtils.js +3 -3
- package/package.json +1 -1
package/dist/UserEvents.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { UserEvent } from
|
|
2
|
-
import { Model } from
|
|
3
|
-
import { ActivityLogCreatedProps } from
|
|
1
|
+
import { UserEvent } from "./common/DomainEvents";
|
|
2
|
+
import { Model } from "./common/Model";
|
|
3
|
+
import { ActivityLogCreatedProps } from "./ActivityLogEvents";
|
|
4
4
|
export interface UserModel extends Model {
|
|
5
5
|
uid?: string;
|
|
6
6
|
displayName: string;
|
|
@@ -16,6 +16,7 @@ export interface UserModel extends Model {
|
|
|
16
16
|
updatedBy: string;
|
|
17
17
|
}
|
|
18
18
|
export interface UserCreatedProps {
|
|
19
|
+
eventId: string;
|
|
19
20
|
userId: string;
|
|
20
21
|
firebaseUid: string;
|
|
21
22
|
displayName: string;
|
|
@@ -30,6 +31,7 @@ export interface UserCreatedProps {
|
|
|
30
31
|
systemGenerated: boolean;
|
|
31
32
|
}
|
|
32
33
|
export declare class UserCreated implements UserEvent {
|
|
34
|
+
eventId: string;
|
|
33
35
|
userId: string;
|
|
34
36
|
firebaseUid: string;
|
|
35
37
|
displayName: string;
|
|
@@ -47,6 +49,7 @@ export declare class UserCreated implements UserEvent {
|
|
|
47
49
|
activityLog(_existing?: Model, actorName?: string): ActivityLogCreatedProps | undefined;
|
|
48
50
|
}
|
|
49
51
|
export interface PlaceholderUserCreatedProps {
|
|
52
|
+
eventId: string;
|
|
50
53
|
userId: string;
|
|
51
54
|
displayName: string;
|
|
52
55
|
phoneNumber?: string;
|
|
@@ -58,6 +61,7 @@ export interface PlaceholderUserCreatedProps {
|
|
|
58
61
|
systemGenerated: boolean;
|
|
59
62
|
}
|
|
60
63
|
export declare class PlaceholderUserCreated implements UserEvent {
|
|
64
|
+
eventId: string;
|
|
61
65
|
userId: string;
|
|
62
66
|
displayName: string;
|
|
63
67
|
phoneNumber?: string;
|
|
@@ -71,6 +75,7 @@ export declare class PlaceholderUserCreated implements UserEvent {
|
|
|
71
75
|
apply(_existing?: Model): UserModel;
|
|
72
76
|
}
|
|
73
77
|
export interface UserCurrencyChangedProps {
|
|
78
|
+
eventId: string;
|
|
74
79
|
userId: string;
|
|
75
80
|
currency?: string;
|
|
76
81
|
createdAt: Date;
|
|
@@ -80,6 +85,7 @@ export interface UserCurrencyChangedProps {
|
|
|
80
85
|
systemGenerated: boolean;
|
|
81
86
|
}
|
|
82
87
|
export declare class UserCurrencyChanged implements UserEvent {
|
|
88
|
+
eventId: string;
|
|
83
89
|
userId: string;
|
|
84
90
|
currency?: string;
|
|
85
91
|
createdAt: Date;
|
|
@@ -92,6 +98,7 @@ export declare class UserCurrencyChanged implements UserEvent {
|
|
|
92
98
|
activityLog(existing?: Model, actorName?: string): ActivityLogCreatedProps | undefined;
|
|
93
99
|
}
|
|
94
100
|
export interface UserPhoneNumberChangedProps {
|
|
101
|
+
eventId: string;
|
|
95
102
|
userId: string;
|
|
96
103
|
phoneNumber?: string;
|
|
97
104
|
createdAt: Date;
|
|
@@ -101,6 +108,7 @@ export interface UserPhoneNumberChangedProps {
|
|
|
101
108
|
systemGenerated: boolean;
|
|
102
109
|
}
|
|
103
110
|
export declare class UserPhoneNumberChanged implements UserEvent {
|
|
111
|
+
eventId: string;
|
|
104
112
|
userId: string;
|
|
105
113
|
phoneNumber?: string;
|
|
106
114
|
createdAt: Date;
|
|
@@ -113,6 +121,7 @@ export declare class UserPhoneNumberChanged implements UserEvent {
|
|
|
113
121
|
activityLog(existing?: Model, actorName?: string): ActivityLogCreatedProps | undefined;
|
|
114
122
|
}
|
|
115
123
|
export interface UserDisplayNameChangedProps {
|
|
124
|
+
eventId: string;
|
|
116
125
|
userId: string;
|
|
117
126
|
displayName: string;
|
|
118
127
|
createdAt: Date;
|
|
@@ -122,6 +131,7 @@ export interface UserDisplayNameChangedProps {
|
|
|
122
131
|
systemGenerated: boolean;
|
|
123
132
|
}
|
|
124
133
|
export declare class UserDisplayNameChanged implements UserEvent {
|
|
134
|
+
eventId: string;
|
|
125
135
|
userId: string;
|
|
126
136
|
displayName: string;
|
|
127
137
|
createdAt: Date;
|
|
@@ -134,6 +144,7 @@ export declare class UserDisplayNameChanged implements UserEvent {
|
|
|
134
144
|
activityLog(existing?: Model, actorName?: string): ActivityLogCreatedProps | undefined;
|
|
135
145
|
}
|
|
136
146
|
export interface UserDeletedProps {
|
|
147
|
+
eventId: string;
|
|
137
148
|
userId: string;
|
|
138
149
|
createdAt: Date;
|
|
139
150
|
createdBy: string;
|
|
@@ -142,6 +153,7 @@ export interface UserDeletedProps {
|
|
|
142
153
|
systemGenerated: boolean;
|
|
143
154
|
}
|
|
144
155
|
export declare class UserDeleted implements UserEvent {
|
|
156
|
+
eventId: string;
|
|
145
157
|
userId: string;
|
|
146
158
|
createdAt: Date;
|
|
147
159
|
createdBy: string;
|
|
@@ -150,8 +162,10 @@ export declare class UserDeleted implements UserEvent {
|
|
|
150
162
|
systemGenerated: boolean;
|
|
151
163
|
constructor(props: UserDeletedProps);
|
|
152
164
|
apply(existing?: Model): UserModel;
|
|
165
|
+
activityLog(existing?: Model, actorName?: string): ActivityLogCreatedProps | undefined;
|
|
153
166
|
}
|
|
154
167
|
export interface PlaceholderUserMergedProps {
|
|
168
|
+
eventId: string;
|
|
155
169
|
userId: string;
|
|
156
170
|
firebaseUid: string;
|
|
157
171
|
displayName: string;
|
|
@@ -166,6 +180,7 @@ export interface PlaceholderUserMergedProps {
|
|
|
166
180
|
systemGenerated: boolean;
|
|
167
181
|
}
|
|
168
182
|
export declare class PlaceholderUserMerged implements UserEvent {
|
|
183
|
+
eventId: string;
|
|
169
184
|
userId: string;
|
|
170
185
|
firebaseUid: string;
|
|
171
186
|
displayName: string;
|
|
@@ -182,6 +197,7 @@ export declare class PlaceholderUserMerged implements UserEvent {
|
|
|
182
197
|
apply(existing?: Model): UserModel;
|
|
183
198
|
}
|
|
184
199
|
export interface UserConvertedToPlaceholderProps {
|
|
200
|
+
eventId: string;
|
|
185
201
|
userId: string;
|
|
186
202
|
createdAt: Date;
|
|
187
203
|
createdBy: string;
|
|
@@ -190,6 +206,7 @@ export interface UserConvertedToPlaceholderProps {
|
|
|
190
206
|
systemGenerated: boolean;
|
|
191
207
|
}
|
|
192
208
|
export declare class UserConvertedToPlaceholder implements UserEvent {
|
|
209
|
+
eventId: string;
|
|
193
210
|
userId: string;
|
|
194
211
|
createdAt: Date;
|
|
195
212
|
createdBy: string;
|
package/dist/UserEvents.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UserEvents.d.ts","sourceRoot":"","sources":["../src/UserEvents.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAkB,MAAM,uBAAuB,CAAC;AAClE,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,uBAAuB,EAAc,MAAM,qBAAqB,CAAC;AAI1E,MAAM,WAAW,SAAU,SAAQ,KAAK;
|
|
1
|
+
{"version":3,"file":"UserEvents.d.ts","sourceRoot":"","sources":["../src/UserEvents.ts"],"names":[],"mappings":"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"}
|
package/dist/UserEvents.js
CHANGED
|
@@ -5,6 +5,7 @@ const ActivityLogEvents_1 = require("./ActivityLogEvents");
|
|
|
5
5
|
const uuid_1 = require("uuid");
|
|
6
6
|
class UserCreated {
|
|
7
7
|
constructor(props) {
|
|
8
|
+
this.eventId = props.eventId;
|
|
8
9
|
this.userId = props.userId;
|
|
9
10
|
this.firebaseUid = props.firebaseUid;
|
|
10
11
|
this.displayName = props.displayName;
|
|
@@ -39,10 +40,11 @@ class UserCreated {
|
|
|
39
40
|
};
|
|
40
41
|
}
|
|
41
42
|
activityLog(_existing, actorName) {
|
|
42
|
-
const actor = actorName ??
|
|
43
|
-
const possessive = actor ===
|
|
43
|
+
const actor = actorName ?? "You";
|
|
44
|
+
const possessive = actor === "You" ? "your" : `${actor}'s`;
|
|
44
45
|
const logMessage = `${actor} created ${possessive} profile as "${this.displayName}"`;
|
|
45
46
|
return {
|
|
47
|
+
eventId: (0, uuid_1.v4)(),
|
|
46
48
|
userId: this.userId,
|
|
47
49
|
activityByUid: this.createdBy,
|
|
48
50
|
sourceStreamId: this.streamId,
|
|
@@ -60,6 +62,7 @@ class UserCreated {
|
|
|
60
62
|
exports.UserCreated = UserCreated;
|
|
61
63
|
class PlaceholderUserCreated {
|
|
62
64
|
constructor(props) {
|
|
65
|
+
this.eventId = props.eventId;
|
|
63
66
|
this.userId = props.userId;
|
|
64
67
|
this.displayName = props.displayName;
|
|
65
68
|
this.phoneNumber = props.phoneNumber;
|
|
@@ -94,6 +97,7 @@ class PlaceholderUserCreated {
|
|
|
94
97
|
exports.PlaceholderUserCreated = PlaceholderUserCreated;
|
|
95
98
|
class UserCurrencyChanged {
|
|
96
99
|
constructor(props) {
|
|
100
|
+
this.eventId = props.eventId;
|
|
97
101
|
this.userId = props.userId;
|
|
98
102
|
this.currency = props.currency;
|
|
99
103
|
this.createdAt = props.createdAt;
|
|
@@ -104,7 +108,7 @@ class UserCurrencyChanged {
|
|
|
104
108
|
}
|
|
105
109
|
apply(existing) {
|
|
106
110
|
if (!existing) {
|
|
107
|
-
throw new Error(
|
|
111
|
+
throw new Error("User must exist to change currency");
|
|
108
112
|
}
|
|
109
113
|
const existingUser = existing;
|
|
110
114
|
return {
|
|
@@ -120,12 +124,13 @@ class UserCurrencyChanged {
|
|
|
120
124
|
return undefined;
|
|
121
125
|
}
|
|
122
126
|
const existingUser = existing;
|
|
123
|
-
const actor = actorName ??
|
|
124
|
-
const possessive = actor ===
|
|
125
|
-
const oldValue = existingUser.currency ??
|
|
126
|
-
const newValue = this.currency ??
|
|
127
|
+
const actor = actorName ?? "You";
|
|
128
|
+
const possessive = actor === "You" ? "your" : `${actor}'s`;
|
|
129
|
+
const oldValue = existingUser.currency ?? "";
|
|
130
|
+
const newValue = this.currency ?? "";
|
|
127
131
|
const logMessage = `${actor} changed ${possessive} currency from ${oldValue} to ${newValue}`;
|
|
128
132
|
return {
|
|
133
|
+
eventId: (0, uuid_1.v4)(),
|
|
129
134
|
userId: existingUser.userId,
|
|
130
135
|
activityByUid: this.createdBy,
|
|
131
136
|
sourceStreamId: this.streamId,
|
|
@@ -143,6 +148,7 @@ class UserCurrencyChanged {
|
|
|
143
148
|
exports.UserCurrencyChanged = UserCurrencyChanged;
|
|
144
149
|
class UserPhoneNumberChanged {
|
|
145
150
|
constructor(props) {
|
|
151
|
+
this.eventId = props.eventId;
|
|
146
152
|
this.userId = props.userId;
|
|
147
153
|
this.phoneNumber = props.phoneNumber;
|
|
148
154
|
this.createdAt = props.createdAt;
|
|
@@ -153,7 +159,7 @@ class UserPhoneNumberChanged {
|
|
|
153
159
|
}
|
|
154
160
|
apply(existing) {
|
|
155
161
|
if (!existing) {
|
|
156
|
-
throw new Error(
|
|
162
|
+
throw new Error("User must exist to change phone number");
|
|
157
163
|
}
|
|
158
164
|
const existingUser = existing;
|
|
159
165
|
return {
|
|
@@ -169,8 +175,8 @@ class UserPhoneNumberChanged {
|
|
|
169
175
|
return undefined;
|
|
170
176
|
}
|
|
171
177
|
const existingUser = existing;
|
|
172
|
-
const actor = actorName ??
|
|
173
|
-
const possessive = actor ===
|
|
178
|
+
const actor = actorName ?? "You";
|
|
179
|
+
const possessive = actor === "You" ? "your" : `${actor}'s`;
|
|
174
180
|
let logMessage;
|
|
175
181
|
if (existingUser.phoneNumber && this.phoneNumber) {
|
|
176
182
|
logMessage = `${actor} changed ${possessive} phone number from ${existingUser.phoneNumber} to ${this.phoneNumber}`;
|
|
@@ -182,6 +188,7 @@ class UserPhoneNumberChanged {
|
|
|
182
188
|
logMessage = `${actor} removed ${possessive} phone number`;
|
|
183
189
|
}
|
|
184
190
|
return {
|
|
191
|
+
eventId: (0, uuid_1.v4)(),
|
|
185
192
|
userId: existingUser.userId,
|
|
186
193
|
activityByUid: this.createdBy,
|
|
187
194
|
sourceStreamId: this.streamId,
|
|
@@ -199,6 +206,7 @@ class UserPhoneNumberChanged {
|
|
|
199
206
|
exports.UserPhoneNumberChanged = UserPhoneNumberChanged;
|
|
200
207
|
class UserDisplayNameChanged {
|
|
201
208
|
constructor(props) {
|
|
209
|
+
this.eventId = props.eventId;
|
|
202
210
|
this.userId = props.userId;
|
|
203
211
|
this.displayName = props.displayName;
|
|
204
212
|
this.createdAt = props.createdAt;
|
|
@@ -209,7 +217,7 @@ class UserDisplayNameChanged {
|
|
|
209
217
|
}
|
|
210
218
|
apply(existing) {
|
|
211
219
|
if (!existing) {
|
|
212
|
-
throw new Error(
|
|
220
|
+
throw new Error("User must exist to change display name");
|
|
213
221
|
}
|
|
214
222
|
const existingUser = existing;
|
|
215
223
|
return {
|
|
@@ -225,10 +233,11 @@ class UserDisplayNameChanged {
|
|
|
225
233
|
return undefined;
|
|
226
234
|
}
|
|
227
235
|
const existingUser = existing;
|
|
228
|
-
const actor = actorName ??
|
|
229
|
-
const possessive = actor ===
|
|
236
|
+
const actor = actorName ?? "You";
|
|
237
|
+
const possessive = actor === "You" ? "your" : `${actor}'s`;
|
|
230
238
|
const logMessage = `${actor} changed ${possessive} name from "${existingUser.displayName}" to "${this.displayName}"`;
|
|
231
239
|
return {
|
|
240
|
+
eventId: (0, uuid_1.v4)(),
|
|
232
241
|
userId: existingUser.userId,
|
|
233
242
|
activityByUid: this.createdBy,
|
|
234
243
|
sourceStreamId: this.streamId,
|
|
@@ -246,6 +255,7 @@ class UserDisplayNameChanged {
|
|
|
246
255
|
exports.UserDisplayNameChanged = UserDisplayNameChanged;
|
|
247
256
|
class UserDeleted {
|
|
248
257
|
constructor(props) {
|
|
258
|
+
this.eventId = props.eventId;
|
|
249
259
|
this.userId = props.userId;
|
|
250
260
|
this.createdAt = props.createdAt;
|
|
251
261
|
this.createdBy = props.createdBy;
|
|
@@ -255,7 +265,7 @@ class UserDeleted {
|
|
|
255
265
|
}
|
|
256
266
|
apply(existing) {
|
|
257
267
|
if (!existing) {
|
|
258
|
-
throw new Error(
|
|
268
|
+
throw new Error("User must exist to delete");
|
|
259
269
|
}
|
|
260
270
|
const existingUser = existing;
|
|
261
271
|
return {
|
|
@@ -266,10 +276,34 @@ class UserDeleted {
|
|
|
266
276
|
deleted: true,
|
|
267
277
|
};
|
|
268
278
|
}
|
|
279
|
+
activityLog(existing, actorName) {
|
|
280
|
+
if (!existing) {
|
|
281
|
+
return undefined;
|
|
282
|
+
}
|
|
283
|
+
const existingUser = existing;
|
|
284
|
+
const actor = actorName ?? "You";
|
|
285
|
+
const possessive = actor === "You" ? "your" : `${actor}'s`;
|
|
286
|
+
const logMessage = `${actor} deleted ${possessive} account`;
|
|
287
|
+
return {
|
|
288
|
+
eventId: (0, uuid_1.v4)(),
|
|
289
|
+
userId: existingUser.userId,
|
|
290
|
+
activityByUid: this.createdBy,
|
|
291
|
+
sourceStreamId: this.streamId,
|
|
292
|
+
sourceType: ActivityLogEvents_1.SourceType.User,
|
|
293
|
+
logMessage,
|
|
294
|
+
date: this.createdAt,
|
|
295
|
+
createdAt: this.createdAt,
|
|
296
|
+
createdBy: this.createdBy,
|
|
297
|
+
streamId: (0, uuid_1.v4)(),
|
|
298
|
+
systemGenerated: true,
|
|
299
|
+
version: 1,
|
|
300
|
+
};
|
|
301
|
+
}
|
|
269
302
|
}
|
|
270
303
|
exports.UserDeleted = UserDeleted;
|
|
271
304
|
class PlaceholderUserMerged {
|
|
272
305
|
constructor(props) {
|
|
306
|
+
this.eventId = props.eventId;
|
|
273
307
|
this.userId = props.userId;
|
|
274
308
|
this.firebaseUid = props.firebaseUid;
|
|
275
309
|
this.displayName = props.displayName;
|
|
@@ -285,11 +319,11 @@ class PlaceholderUserMerged {
|
|
|
285
319
|
}
|
|
286
320
|
apply(existing) {
|
|
287
321
|
if (!existing) {
|
|
288
|
-
throw new Error(
|
|
322
|
+
throw new Error("Placeholder user must exist to merge");
|
|
289
323
|
}
|
|
290
324
|
const existingUser = existing;
|
|
291
325
|
if (!existingUser.isPlaceholder) {
|
|
292
|
-
throw new Error(
|
|
326
|
+
throw new Error("Can only merge placeholder users");
|
|
293
327
|
}
|
|
294
328
|
return {
|
|
295
329
|
...existingUser,
|
|
@@ -309,6 +343,7 @@ class PlaceholderUserMerged {
|
|
|
309
343
|
exports.PlaceholderUserMerged = PlaceholderUserMerged;
|
|
310
344
|
class UserConvertedToPlaceholder {
|
|
311
345
|
constructor(props) {
|
|
346
|
+
this.eventId = props.eventId;
|
|
312
347
|
this.userId = props.userId;
|
|
313
348
|
this.createdAt = props.createdAt;
|
|
314
349
|
this.createdBy = props.createdBy;
|
|
@@ -318,11 +353,11 @@ class UserConvertedToPlaceholder {
|
|
|
318
353
|
}
|
|
319
354
|
apply(existing) {
|
|
320
355
|
if (!existing) {
|
|
321
|
-
throw new Error(
|
|
356
|
+
throw new Error("User must exist to convert to placeholder");
|
|
322
357
|
}
|
|
323
358
|
const existingUser = existing;
|
|
324
359
|
if (existingUser.isPlaceholder) {
|
|
325
|
-
throw new Error(
|
|
360
|
+
throw new Error("User is already a placeholder");
|
|
326
361
|
}
|
|
327
362
|
return {
|
|
328
363
|
...existingUser,
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"firebaseEmulator.d.ts","sourceRoot":"","sources":["../../../../src/__tests__/e2e/setup/firebaseEmulator.ts"],"names":[],"mappings":"AAIA,wBAAsB,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC,CAgF3D;AAED,wBAAsB,oBAAoB,IAAI,OAAO,CAAC,IAAI,CAAC,CAyB1D"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.startFirebaseEmulator = startFirebaseEmulator;
|
|
4
|
+
exports.stopFirebaseEmulator = stopFirebaseEmulator;
|
|
5
|
+
const child_process_1 = require("child_process");
|
|
6
|
+
let emulatorProcess = null;
|
|
7
|
+
async function startFirebaseEmulator() {
|
|
8
|
+
console.log("Starting Firebase emulator...");
|
|
9
|
+
return new Promise((resolve, reject) => {
|
|
10
|
+
// Build gcloud-functions first
|
|
11
|
+
console.log("Building gcloud-functions...");
|
|
12
|
+
const buildProcess = (0, child_process_1.spawn)("npm", ["run", "build"], {
|
|
13
|
+
cwd: "../gcloud-functions",
|
|
14
|
+
shell: true,
|
|
15
|
+
});
|
|
16
|
+
buildProcess.on("close", (code) => {
|
|
17
|
+
if (code !== 0) {
|
|
18
|
+
reject(new Error(`Failed to build gcloud-functions: ${code}`));
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
console.log("gcloud-functions built successfully");
|
|
22
|
+
// Start emulator
|
|
23
|
+
emulatorProcess = (0, child_process_1.spawn)("npx", [
|
|
24
|
+
"firebase",
|
|
25
|
+
"emulators:start",
|
|
26
|
+
"--only",
|
|
27
|
+
"firestore,functions",
|
|
28
|
+
], {
|
|
29
|
+
shell: true,
|
|
30
|
+
stdio: "pipe",
|
|
31
|
+
});
|
|
32
|
+
let output = "";
|
|
33
|
+
emulatorProcess.stdout?.on("data", (data) => {
|
|
34
|
+
const str = data.toString();
|
|
35
|
+
output += str;
|
|
36
|
+
console.log(`[Emulator] ${str}`);
|
|
37
|
+
// Wait for emulator to be ready
|
|
38
|
+
if (str.includes("All emulators ready")) {
|
|
39
|
+
console.log("Firebase emulator ready!");
|
|
40
|
+
// Give it a bit more time to fully initialize
|
|
41
|
+
setTimeout(() => resolve(), 2000);
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
emulatorProcess.stderr?.on("data", (data) => {
|
|
45
|
+
console.error(`[Emulator Error] ${data.toString()}`);
|
|
46
|
+
});
|
|
47
|
+
emulatorProcess.on("error", (error) => {
|
|
48
|
+
reject(error);
|
|
49
|
+
});
|
|
50
|
+
emulatorProcess.on("close", (code) => {
|
|
51
|
+
if (code !== 0 && code !== null) {
|
|
52
|
+
reject(new Error(`Emulator exited with code ${code}\nOutput: ${output}`));
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
// Timeout after 60 seconds
|
|
56
|
+
setTimeout(() => {
|
|
57
|
+
if (emulatorProcess) {
|
|
58
|
+
reject(new Error("Timeout waiting for emulator to start\nOutput: " +
|
|
59
|
+
output));
|
|
60
|
+
}
|
|
61
|
+
}, 60000);
|
|
62
|
+
});
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
async function stopFirebaseEmulator() {
|
|
66
|
+
if (emulatorProcess) {
|
|
67
|
+
console.log("Stopping Firebase emulator...");
|
|
68
|
+
return new Promise((resolve) => {
|
|
69
|
+
emulatorProcess.on("close", () => {
|
|
70
|
+
console.log("Firebase emulator stopped");
|
|
71
|
+
emulatorProcess = null;
|
|
72
|
+
resolve();
|
|
73
|
+
});
|
|
74
|
+
// Try graceful shutdown first
|
|
75
|
+
emulatorProcess.kill("SIGTERM");
|
|
76
|
+
// Force kill after 5 seconds if not stopped
|
|
77
|
+
setTimeout(() => {
|
|
78
|
+
if (emulatorProcess && !emulatorProcess.killed) {
|
|
79
|
+
console.log("Force killing emulator...");
|
|
80
|
+
emulatorProcess.kill("SIGKILL");
|
|
81
|
+
emulatorProcess = null;
|
|
82
|
+
resolve();
|
|
83
|
+
}
|
|
84
|
+
}, 5000);
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { FriendEventStore, FriendModelStore, FriendEvent, FriendModel, UserEventStore, UserModelStore, UserEvent, UserModel } from "../../..";
|
|
2
|
+
export declare class FSFriendEventStore extends FriendEventStore {
|
|
3
|
+
addEvent(event: FriendEvent): Promise<void>;
|
|
4
|
+
getEventsByStreamId(streamId: string): Promise<FriendEvent[]>;
|
|
5
|
+
}
|
|
6
|
+
export declare class FSFriendModelStore extends FriendModelStore {
|
|
7
|
+
save(model: FriendModel): Promise<void>;
|
|
8
|
+
getByStreamId(streamId: string): Promise<FriendModel | undefined>;
|
|
9
|
+
getByStreamIdWhereDeletedIsFalse(streamId: string): Promise<FriendModel | undefined>;
|
|
10
|
+
findByUserIdAndFriendIdAndDeletedIsFalse(userId: string, friendId: string): Promise<FriendModel | undefined>;
|
|
11
|
+
getAllByUserId(userId: string): Promise<FriendModel[]>;
|
|
12
|
+
findByUserIdAndStreamIdAndDeletedIsFalse(userId: string, streamId: string): Promise<FriendModel | undefined>;
|
|
13
|
+
findByUserIdAndFriendEmailAndDeletedIsFalse(userId: string, email: string): Promise<FriendModel | undefined>;
|
|
14
|
+
findByUserIdAndFriendPhoneNumberAndDeletedIsFalse(userId: string, phoneNumber: string): Promise<FriendModel | undefined>;
|
|
15
|
+
}
|
|
16
|
+
export declare class FSUserEventStore extends UserEventStore {
|
|
17
|
+
addEvent(event: UserEvent): Promise<void>;
|
|
18
|
+
getEventsByStreamId(streamId: string): Promise<UserEvent[]>;
|
|
19
|
+
}
|
|
20
|
+
export declare class FSUserModelStore extends UserModelStore {
|
|
21
|
+
save(model: UserModel): Promise<void>;
|
|
22
|
+
getByStreamId(streamId: string): Promise<UserModel | undefined>;
|
|
23
|
+
getByStreamIdWhereDeletedIsFalse(streamId: string): Promise<UserModel | undefined>;
|
|
24
|
+
findByEmail(email: string): Promise<UserModel | undefined>;
|
|
25
|
+
findByPhone(phone: string): Promise<UserModel | undefined>;
|
|
26
|
+
findByFirebaseUid(firebaseUid: string): Promise<UserModel | undefined>;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=firestoreStores.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"firestoreStores.d.ts","sourceRoot":"","sources":["../../../../src/__tests__/e2e/setup/firestoreStores.ts"],"names":[],"mappings":"AACA,OAAO,EACH,gBAAgB,EAChB,gBAAgB,EAChB,WAAW,EACX,WAAW,EACX,cAAc,EACd,cAAc,EACd,SAAS,EACT,SAAS,EACZ,MAAM,UAAU,CAAC;AAWlB,qBAAa,kBAAmB,SAAQ,gBAAgB;IAC9C,QAAQ,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAgB3C,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;CAGtE;AAGD,qBAAa,kBAAmB,SAAQ,gBAAgB;IAC9C,IAAI,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAgBvC,aAAa,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC;IAgBjE,gCAAgC,CAClC,QAAQ,EAAE,MAAM,GACjB,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC;IAK7B,wCAAwC,CAC1C,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,GACjB,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC;IAmB7B,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;IAatD,wCAAwC,CAC1C,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,GACjB,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC;IAqB7B,2CAA2C,CAC7C,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,GACd,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC;IAmB7B,iDAAiD,CACnD,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,MAAM,GACpB,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC;CAkBtC;AAGD,qBAAa,gBAAiB,SAAQ,cAAc;IAC1C,QAAQ,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAgBzC,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;CAGpE;AAGD,qBAAa,gBAAiB,SAAQ,cAAc;IAC1C,IAAI,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAgBrC,aAAa,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC;IAgB/D,gCAAgC,CAClC,QAAQ,EAAE,MAAM,GACjB,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC;IAK3B,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC;IAkB1D,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC;IAkB1D,iBAAiB,CACnB,WAAW,EAAE,MAAM,GACpB,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC;CAiBpC"}
|