@twilio/conversations 3.0.0-canary.9 → 3.0.0-canary2.100

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/README.md +22 -18
  2. package/builds/browser.js +1018 -2070
  3. package/builds/browser.js.map +1 -1
  4. package/builds/lib.d.ts +69 -67
  5. package/builds/lib.js +1018 -2070
  6. package/builds/lib.js.map +1 -1
  7. package/builds/twilio-conversations.js +24737 -25259
  8. package/builds/twilio-conversations.min.js +1 -1
  9. package/dist/aggregated-delivery-receipt.js +1 -1
  10. package/dist/aggregated-delivery-receipt.js.map +1 -1
  11. package/dist/client.js +85 -69
  12. package/dist/client.js.map +1 -1
  13. package/dist/command-executor.js +30 -12
  14. package/dist/command-executor.js.map +1 -1
  15. package/dist/conversation.js +87 -19
  16. package/dist/conversation.js.map +1 -1
  17. package/dist/data/conversations.js +20 -4
  18. package/dist/data/conversations.js.map +1 -1
  19. package/dist/data/messages.js +13 -19
  20. package/dist/data/messages.js.map +1 -1
  21. package/dist/data/participants.js +6 -4
  22. package/dist/data/participants.js.map +1 -1
  23. package/dist/data/users.js +4 -2
  24. package/dist/data/users.js.map +1 -1
  25. package/dist/index.js +5 -0
  26. package/dist/index.js.map +1 -1
  27. package/dist/message-builder.js.map +1 -1
  28. package/dist/message.js +15 -12
  29. package/dist/message.js.map +1 -1
  30. package/dist/node_modules/tslib/tslib.es6.js.map +1 -1
  31. package/dist/packages/conversations/package.json.js +1 -1
  32. package/dist/participant.js.map +1 -1
  33. package/dist/push-notification.js.map +1 -1
  34. package/dist/services/network.js +38 -15
  35. package/dist/services/network.js.map +1 -1
  36. package/dist/services/typing-indicator.js +7 -5
  37. package/dist/services/typing-indicator.js.map +1 -1
  38. package/dist/unsent-message.js.map +1 -1
  39. package/dist/user.js +1 -1
  40. package/dist/user.js.map +1 -1
  41. package/dist/util/index.js.map +1 -1
  42. package/package.json +18 -16
@@ -134,7 +134,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
134
134
  * Contains aggregated information about delivery statuses of a message across all participants
135
135
  * of a conversation.
136
136
  *
137
- * At any moment during the message delivery to a participant, the message can have zero or more of following
137
+ * At any moment during the message delivery to a participant, the message can have zero or more of the following
138
138
  * delivery statuses:
139
139
  * * Message is considered as **sent** to a participant if the nearest upstream carrier accepted the message.
140
140
  * * Message is considered as **delivered** to a participant if Twilio has received confirmation of message
@@ -1 +1 @@
1
- {"version":3,"file":"aggregated-delivery-receipt.js","sources":["../src/aggregated-delivery-receipt.ts"],"sourcesContent":["/**\n * Signifies the amount of participants which have the status for the message.\n */\ntype DeliveryAmount = \"none\" | \"some\" | \"all\";\n\ninterface AggregatedDeliveryDescriptor {\n total: number;\n delivered: DeliveryAmount;\n failed: DeliveryAmount;\n read: DeliveryAmount;\n sent: DeliveryAmount;\n undelivered: DeliveryAmount;\n}\n\n/**\n * Contains aggregated information about delivery statuses of a message across all participants\n * of a conversation.\n *\n * At any moment during the message delivery to a participant, the message can have zero or more of following\n * delivery statuses:\n * * Message is considered as **sent** to a participant if the nearest upstream carrier accepted the message.\n * * Message is considered as **delivered** to a participant if Twilio has received confirmation of message\n * delivery from the upstream carrier, and, where available, the destination handset.\n * * Message considered as **undelivered** to a participant if Twilio has received a delivery receipt\n * indicating that the message was not delivered. This can happen for many reasons including carrier content\n * filtering and the availability of the destination handset.\n * * Message considered as **read** by a participant if the message has been delivered and opened by the\n * recipient in a conversation. The recipient must have enabled the read receipts.\n * * Message considered as **failed** to be delivered to a participant if the message could not be sent.\n * This can happen for various reasons including queue overflows, account suspensions and media\n * errors (in the case of MMS for instance).\n *\n * {@link AggregatedDeliveryReceipt} class contains an aggregated value {@link DeliveryAmount} for each delivery status.\n */\nclass AggregatedDeliveryReceipt {\n private state: AggregatedDeliveryDescriptor;\n\n /**\n * @internal\n */\n constructor(data: AggregatedDeliveryDescriptor) {\n this.state = data;\n }\n\n /**\n * Maximum number of delivery events expected for the message.\n */\n public get total(): number {\n return this.state.total;\n }\n\n /**\n * Message is considered as **sent** to a participant if the nearest upstream carrier accepted the message.\n *\n * @return Amount of participants that have the **sent** delivery status for the message.\n */\n public get sent(): DeliveryAmount {\n return this.state.sent;\n }\n\n /**\n * Message is considered as **delivered** to a participant if Twilio has received confirmation of message\n * delivery from the upstream carrier, and, where available, the destination handset.\n *\n * @return Amount of participants that have the **delivered** delivery status for the message.\n */\n public get delivered(): DeliveryAmount {\n return this.state.delivered;\n }\n\n /**\n * Message is considered as **read** by a participant, if the message has been delivered and opened by the\n * recipient in a conversation. The recipient must have enabled the read receipts.\n *\n * @return Amount of participants that have the **read** delivery status for the message.\n */\n public get read(): DeliveryAmount {\n return this.state.read;\n }\n\n /**\n * Message is considered as **undelivered** to a participant if Twilio has received a delivery receipt\n * indicating that the message was not delivered. This can happen for many reasons including carrier content\n * filtering and the availability of the destination handset.\n *\n * @return Ammount of participants that have the **undelivered** delivery status for the message.\n */\n public get undelivered(): DeliveryAmount {\n return this.state.undelivered;\n }\n\n /**\n * Message is considered as **failed** to be delivered to a participant if the message could not be sent.\n * This can happen for various reasons including queue overflows, account suspensions and media\n * errors (in the case of MMS for instance). Twilio does not charge you for failed messages.\n *\n * @return Amount of participants that have the **failed** delivery status for the message.\n */\n public get failed(): DeliveryAmount {\n return this.state.failed;\n }\n\n _update(data: AggregatedDeliveryDescriptor): void {\n this.state = data;\n }\n\n _isEquals(data: AggregatedDeliveryDescriptor): boolean {\n const isTotalSame = this.total === data.total;\n const isSentSame = this.sent === data.sent;\n const isDeliveredSame = this.delivered === data.delivered;\n const isReadSame = this.read === data.read;\n const isUndeliveredSame = this.undelivered === data.undelivered;\n const isFailedSame = this.failed === data.failed;\n\n return (\n isTotalSame &&\n isSentSame &&\n isDeliveredSame &&\n isReadSame &&\n isUndeliveredSame &&\n isFailedSame\n );\n }\n}\n\nexport {\n AggregatedDeliveryReceipt,\n AggregatedDeliveryDescriptor,\n DeliveryAmount,\n};\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAcA;;;;;;;;;;;;;;;;;;;AAmBG;AACH,MAAM,yBAAyB,CAAA;AAG7B;;AAEG;AACH,IAAA,WAAA,CAAY,IAAkC,EAAA;AAC5C,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;KACnB;AAED;;AAEG;AACH,IAAA,IAAW,KAAK,GAAA;AACd,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;KACzB;AAED;;;;AAIG;AACH,IAAA,IAAW,IAAI,GAAA;AACb,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;KACxB;AAED;;;;;AAKG;AACH,IAAA,IAAW,SAAS,GAAA;AAClB,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;KAC7B;AAED;;;;;AAKG;AACH,IAAA,IAAW,IAAI,GAAA;AACb,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;KACxB;AAED;;;;;;AAMG;AACH,IAAA,IAAW,WAAW,GAAA;AACpB,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;KAC/B;AAED;;;;;;AAMG;AACH,IAAA,IAAW,MAAM,GAAA;AACf,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;KAC1B;AAED,IAAA,OAAO,CAAC,IAAkC,EAAA;AACxC,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;KACnB;AAED,IAAA,SAAS,CAAC,IAAkC,EAAA;QAC1C,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC;QAC9C,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC;QAC3C,MAAM,eAAe,GAAG,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,SAAS,CAAC;QAC1D,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC;QAC3C,MAAM,iBAAiB,GAAG,IAAI,CAAC,WAAW,KAAK,IAAI,CAAC,WAAW,CAAC;QAChE,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,MAAM,CAAC;AAEjD,QAAA,QACE,WAAW;YACX,UAAU;YACV,eAAe;YACf,UAAU;YACV,iBAAiB;AACjB,YAAA,YAAY,EACZ;KACH;AACF;;;;"}
1
+ {"version":3,"file":"aggregated-delivery-receipt.js","sources":["../src/aggregated-delivery-receipt.ts"],"sourcesContent":["/**\n * Signifies the amount of participants which have the status for the message.\n */\ntype DeliveryAmount = \"none\" | \"some\" | \"all\";\n\ninterface AggregatedDeliveryDescriptor {\n total: number;\n delivered: DeliveryAmount;\n failed: DeliveryAmount;\n read: DeliveryAmount;\n sent: DeliveryAmount;\n undelivered: DeliveryAmount;\n}\n\n/**\n * Contains aggregated information about delivery statuses of a message across all participants\n * of a conversation.\n *\n * At any moment during the message delivery to a participant, the message can have zero or more of the following\n * delivery statuses:\n * * Message is considered as **sent** to a participant if the nearest upstream carrier accepted the message.\n * * Message is considered as **delivered** to a participant if Twilio has received confirmation of message\n * delivery from the upstream carrier, and, where available, the destination handset.\n * * Message considered as **undelivered** to a participant if Twilio has received a delivery receipt\n * indicating that the message was not delivered. This can happen for many reasons including carrier content\n * filtering and the availability of the destination handset.\n * * Message considered as **read** by a participant if the message has been delivered and opened by the\n * recipient in a conversation. The recipient must have enabled the read receipts.\n * * Message considered as **failed** to be delivered to a participant if the message could not be sent.\n * This can happen for various reasons including queue overflows, account suspensions and media\n * errors (in the case of MMS for instance).\n *\n * {@link AggregatedDeliveryReceipt} class contains an aggregated value {@link DeliveryAmount} for each delivery status.\n */\nclass AggregatedDeliveryReceipt {\n private state: AggregatedDeliveryDescriptor;\n\n /**\n * @internal\n */\n constructor(data: AggregatedDeliveryDescriptor) {\n this.state = data;\n }\n\n /**\n * Maximum number of delivery events expected for the message.\n */\n public get total(): number {\n return this.state.total;\n }\n\n /**\n * Message is considered as **sent** to a participant if the nearest upstream carrier accepted the message.\n *\n * @return Amount of participants that have the **sent** delivery status for the message.\n */\n public get sent(): DeliveryAmount {\n return this.state.sent;\n }\n\n /**\n * Message is considered as **delivered** to a participant if Twilio has received confirmation of message\n * delivery from the upstream carrier, and, where available, the destination handset.\n *\n * @return Amount of participants that have the **delivered** delivery status for the message.\n */\n public get delivered(): DeliveryAmount {\n return this.state.delivered;\n }\n\n /**\n * Message is considered as **read** by a participant, if the message has been delivered and opened by the\n * recipient in a conversation. The recipient must have enabled the read receipts.\n *\n * @return Amount of participants that have the **read** delivery status for the message.\n */\n public get read(): DeliveryAmount {\n return this.state.read;\n }\n\n /**\n * Message is considered as **undelivered** to a participant if Twilio has received a delivery receipt\n * indicating that the message was not delivered. This can happen for many reasons including carrier content\n * filtering and the availability of the destination handset.\n *\n * @return Ammount of participants that have the **undelivered** delivery status for the message.\n */\n public get undelivered(): DeliveryAmount {\n return this.state.undelivered;\n }\n\n /**\n * Message is considered as **failed** to be delivered to a participant if the message could not be sent.\n * This can happen for various reasons including queue overflows, account suspensions and media\n * errors (in the case of MMS for instance). Twilio does not charge you for failed messages.\n *\n * @return Amount of participants that have the **failed** delivery status for the message.\n */\n public get failed(): DeliveryAmount {\n return this.state.failed;\n }\n\n _update(data: AggregatedDeliveryDescriptor): void {\n this.state = data;\n }\n\n _isEquals(data: AggregatedDeliveryDescriptor): boolean {\n const isTotalSame = this.total === data.total;\n const isSentSame = this.sent === data.sent;\n const isDeliveredSame = this.delivered === data.delivered;\n const isReadSame = this.read === data.read;\n const isUndeliveredSame = this.undelivered === data.undelivered;\n const isFailedSame = this.failed === data.failed;\n\n return (\n isTotalSame &&\n isSentSame &&\n isDeliveredSame &&\n isReadSame &&\n isUndeliveredSame &&\n isFailedSame\n );\n }\n}\n\nexport {\n AggregatedDeliveryReceipt,\n AggregatedDeliveryDescriptor,\n DeliveryAmount,\n};\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAcA;;;;;;;;;;;;;;;;;;;AAmBG;AACH,MAAM,yBAAyB,CAAA;AAG7B;;AAEG;AACH,IAAA,WAAA,CAAY,IAAkC,EAAA;AAC5C,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;KACnB;AAED;;AAEG;AACH,IAAA,IAAW,KAAK,GAAA;AACd,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;KACzB;AAED;;;;AAIG;AACH,IAAA,IAAW,IAAI,GAAA;AACb,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;KACxB;AAED;;;;;AAKG;AACH,IAAA,IAAW,SAAS,GAAA;AAClB,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;KAC7B;AAED;;;;;AAKG;AACH,IAAA,IAAW,IAAI,GAAA;AACb,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;KACxB;AAED;;;;;;AAMG;AACH,IAAA,IAAW,WAAW,GAAA;AACpB,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;KAC/B;AAED;;;;;;AAMG;AACH,IAAA,IAAW,MAAM,GAAA;AACf,QAAA,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;KAC1B;AAED,IAAA,OAAO,CAAC,IAAkC,EAAA;AACxC,QAAA,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;KACnB;AAED,IAAA,SAAS,CAAC,IAAkC,EAAA;QAC1C,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC;QAC9C,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC;QAC3C,MAAM,eAAe,GAAG,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,SAAS,CAAC;QAC1D,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC;QAC3C,MAAM,iBAAiB,GAAG,IAAI,CAAC,WAAW,KAAK,IAAI,CAAC,WAAW,CAAC;QAChE,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,MAAM,CAAC;AAEjD,QAAA,QACE,WAAW;YACX,UAAU;YACV,eAAe;YACf,UAAU;YACV,iBAAiB;AACjB,YAAA,YAAY,EACZ;KACH;AACF;;;;"}
package/dist/client.js CHANGED
@@ -233,14 +233,37 @@ exports.Client = Client_1 = class Client extends replayEventEmitter.ReplayEventE
233
233
  this._options.initRegistrations = [initRegistration];
234
234
  }
235
235
  this._services.twilsockClient = this._options.twilsockClient =
236
- (_b = this._options.twilsockClient) !== null && _b !== void 0 ? _b : new twilsock.TwilsockClient(fpaToken, productId, this._options);
236
+ (_b = this._options.twilsockClient) !== null && _b !== void 0 ? _b :
237
+ // todo: remove any after the release of new Twilsock
238
+ new twilsock.TwilsockClient(fpaToken, productId, this._options);
237
239
  this._services.twilsockClient.on("tokenAboutToExpire", () => this.emit("tokenAboutToExpire"));
238
240
  this._services.twilsockClient.on("tokenExpired", () => this.emit("tokenExpired"));
239
- this._services.twilsockClient.on("connectionError", (error) => this.emit("connectionError", error));
240
- this._services.twilsockClient.on("stateChanged", (state) => {
241
- Client_1._logger.debug(`Handling stateChanged for ConversationsClient: new state ${state}`);
242
- if (state !== this.connectionState) {
243
- this.connectionState = state;
241
+ // this._services.twilsockClient.on("connectionError", (error) =>
242
+ // this.emit("connectionError", error)
243
+ // );
244
+ // this._services.twilsockClient.on(
245
+ // "stateChanged",
246
+ // (state: ConnectionState) => {
247
+ // }
248
+ // );
249
+ this._services.twilsockClient.on("disconnected", () => {
250
+ Client_1._logger.debug(`Handling stateChanged for ConversationsClient: new state disconnected`);
251
+ if ("disconnected" !== this.connectionState) {
252
+ this.connectionState = "disconnected";
253
+ this.emit("connectionStateChanged", this.connectionState);
254
+ }
255
+ });
256
+ this._services.twilsockClient.on("connecting", () => {
257
+ Client_1._logger.debug(`Handling stateChanged for ConversationsClient: new state connecting`);
258
+ if ("connecting" !== this.connectionState) {
259
+ this.connectionState = "connecting";
260
+ this.emit("connectionStateChanged", this.connectionState);
261
+ }
262
+ });
263
+ this._services.twilsockClient.on("connected", () => {
264
+ Client_1._logger.debug(`Handling stateChanged for ConversationsClient: new state connected`);
265
+ if ("connected" !== this.connectionState) {
266
+ this.connectionState = "connected";
244
267
  this.emit("connectionStateChanged", this.connectionState);
245
268
  }
246
269
  });
@@ -249,7 +272,12 @@ exports.Client = Client_1 = class Client extends replayEventEmitter.ReplayEventE
249
272
  this._services.notificationClient = this._options.notificationsClient =
250
273
  (_d = this._options.notificationsClient) !== null && _d !== void 0 ? _d : new notifications.Notifications(fpaToken, this._options);
251
274
  this._services.syncClient = this._options.syncClient =
252
- (_e = this._options.syncClient) !== null && _e !== void 0 ? _e : new twilioSync.SyncClient(fpaToken, this._options);
275
+ (_e = this._options.syncClient) !== null && _e !== void 0 ? _e :
276
+ // TwilsockClient is different between versions 0.12.2
277
+ // (dep of twilio-sync@3.2.2) and 0.13.1 (dep of current
278
+ // @twilio/conversations). Thus, casting to any.
279
+ // todo: fix sync caching and migrate to that version of sync.
280
+ new twilioSync.SyncClient(fpaToken, this._options);
253
281
  const configurationOptions = (options === null || options === void 0 ? void 0 : options.Chat) || (options === null || options === void 0 ? void 0 : options.IPMessaging) || options || {};
254
282
  const region = configurationOptions.region || (options === null || options === void 0 ? void 0 : options.region);
255
283
  const baseUrl = configurationOptions.apiUri ||
@@ -258,24 +286,48 @@ exports.Client = Client_1 = class Client extends replayEventEmitter.ReplayEventE
258
286
  this._services.commandExecutor = new commandExecutor.CommandExecutor(baseUrl, { transport: this._options.transport }, productId);
259
287
  const emitFailed = (error) => {
260
288
  this._rejectEnsureReady(error);
261
- this.emit("stateChanged", { state: "failed", error });
289
+ this.emit("initFailed", { error });
262
290
  };
263
- this._services.twilsockClient.onceWithReplay("connectionError", emitFailed);
264
- this._services.twilsockClient.onceWithReplay("disconnected", emitFailed);
265
- this._services.twilsockClient.onceWithReplay("connected", async () => {
291
+ const emitDisconnected = () => {
292
+ emitFailed({
293
+ terminal: true,
294
+ message: "Twilsock has disconnected.",
295
+ });
296
+ };
297
+ // this._services.twilsockClient.once("connectionError", emitFailed);
298
+ this._services.twilsockClient.once("disconnected", emitDisconnected);
299
+ this._services.twilsockClient.once("connected", async () => {
266
300
  Client_1._logger.debug(`ConversationsClient started INITIALIZING`);
267
- this._services.twilsockClient.off("connectionError", emitFailed);
268
- this._services.twilsockClient.off("disconnected", emitFailed);
301
+ // this._services.twilsockClient.off("connectionError", emitFailed);
302
+ this._services.twilsockClient.off("disconnected", emitDisconnected);
269
303
  try {
270
304
  const startupEvent = "conversations.client.startup";
271
- this._services.twilsockClient.addPartialTelemetryEvent(new twilsock.TelemetryEventDescription(startupEvent, "Conversations client startup", new Date()), startupEvent, twilsock.TelemetryPoint.Start);
305
+ // this._services.twilsockClient.addPartialTelemetryEvent(
306
+ // new TelemetryEventDescription(
307
+ // startupEvent,
308
+ // "Conversations client startup",
309
+ // new Date()
310
+ // ),
311
+ // startupEvent,
312
+ // TelemetryPoint.Start
313
+ // );
272
314
  await this._initialize();
273
- this._services.twilsockClient.addPartialTelemetryEvent(new twilsock.TelemetryEventDescription("", "", new Date()), startupEvent, twilsock.TelemetryPoint.End);
315
+ // this._services.twilsockClient.addPartialTelemetryEvent(
316
+ // new TelemetryEventDescription("", "", new Date()),
317
+ // startupEvent,
318
+ // TelemetryPoint.End
319
+ // );
274
320
  }
275
321
  catch (err) {
276
322
  // Fail ChatClient if initialization is incomplete
277
- this._rejectEnsureReady(err);
278
- this.emit("stateChanged", { state: "failed", error: err });
323
+ const connectionError = {
324
+ terminal: true,
325
+ message: err.message,
326
+ };
327
+ this._rejectEnsureReady(connectionError);
328
+ this.emit("initFailed", {
329
+ error: connectionError,
330
+ });
279
331
  }
280
332
  });
281
333
  this._ensureReady = new Promise((resolve, reject) => {
@@ -301,52 +353,18 @@ exports.Client = Client_1 = class Client extends replayEventEmitter.ReplayEventE
301
353
  get reachabilityEnabled() {
302
354
  if (!this._configuration) {
303
355
  throw new Error("Reachability information could not yet be accessed as the client " +
304
- "has not yet been initialized. Subscribe to the 'stateChanged' event " +
305
- "to properly react to the client initialization.");
356
+ "has not yet been initialized. Subscribe to 'initialized' and " +
357
+ "'initFailed' events to properly react to the client initialization.");
306
358
  }
307
359
  return this._configuration.reachabilityEnabled;
308
360
  }
309
- /**
310
- * @deprecated Call constructor directly.
311
- *
312
- * Factory method to create a Conversations client instance.
313
- *
314
- * The factory method will automatically trigger connection.
315
- * Do not use it if you need finer-grained control.
316
- *
317
- * Since this method returns an already-initialized client, some of the events
318
- * will be lost because they happen *before* the initialization. It is
319
- * recommended that `client.onWithReplay` is used as opposed to `client.on`
320
- * for subscribing to client events. The `client.onWithReplay` will re-emit
321
- * the most recent value for a given event if it emitted before the
322
- * subscription.
323
- *
324
- * @param token Access token.
325
- * @param options Options to customize the client.
326
- * @returns Returns a fully initialized client.
327
- */
328
- static async create(token, options) {
329
- // The logic is as follows:
330
- // - If twilsock is not passed in, then the ConversationsClient constructor will call twilsock.connect() by itself
331
- // and we do not need to do it here.
332
- // - If twilsock was passed in from the outside, but customer called ConversationsClient.create() then they are
333
- // using an obsolete workflow and the startup sequence will never complete.
334
- if (options === null || options === void 0 ? void 0 : options.twilsockClient) {
335
- throw new Error("Obsolete usage of ConversationsClient.create() " +
336
- "factory method: if you pass twilsock from the outside then you must " +
337
- "use ConversationsClient constructor and be prepared to work with " +
338
- "uninitialized client.");
339
- }
340
- const client = new Client_1(token, options);
341
- await client._ensureReady;
342
- return client;
343
- }
344
361
  /**
345
362
  * Static method for push notification payload parsing. Returns parsed push as
346
363
  * a {@link PushNotification} object.
347
364
  * @param notificationPayload Push notification payload.
348
365
  */
349
366
  static parsePushNotification(notificationPayload) {
367
+ var _a, _b;
350
368
  Client_1._logger.debug("parsePushNotification, notificationPayload=", notificationPayload);
351
369
  // APNS specifics
352
370
  if (typeof notificationPayload.aps !== "undefined") {
@@ -361,8 +379,8 @@ exports.Client = Client_1 = class Client extends replayEventEmitter.ReplayEventE
361
379
  body = apsPayload.alert || null;
362
380
  }
363
381
  else {
364
- body = apsPayload.alert.body || null;
365
- title = apsPayload.alert.title || null;
382
+ body = ((_a = apsPayload.alert) === null || _a === void 0 ? void 0 : _a.body) || null;
383
+ title = ((_b = apsPayload.alert) === null || _b === void 0 ? void 0 : _b.title) || null;
366
384
  }
367
385
  return new pushNotification.PushNotification({
368
386
  title,
@@ -431,8 +449,8 @@ exports.Client = Client_1 = class Client extends replayEventEmitter.ReplayEventE
431
449
  * @param reg The init registration to populate.
432
450
  */
433
451
  static populateInitRegistrations(reg) {
434
- reg.populateInitRegistrations([notificationTypes.NotificationTypes.TYPING_INDICATOR]);
435
- twilioSync.SyncClient.populateInitRegistrations(reg);
452
+ // reg.populateInitRegistrations([NotificationTypes.TYPING_INDICATOR]);
453
+ // SyncClient.populateInitRegistrations(reg);
436
454
  }
437
455
  /**
438
456
  * Gracefully shut down the client.
@@ -670,7 +688,7 @@ exports.Client = Client_1 = class Client extends replayEventEmitter.ReplayEventE
670
688
  this._services.typingIndicator.initialize();
671
689
  this._services.mcsClient = new mcsClient.McsClient(this._fpaToken, this._configuration.links.mediaService, this._configuration.links.mediaSetService, Object.assign(Object.assign({}, this._options), { transport: undefined }));
672
690
  this._resolveEnsureReady();
673
- this.emit("stateChanged", { state: "initialized" });
691
+ this.emit("initialized");
674
692
  }
675
693
  /**
676
694
  * Subscribe to push notifications.
@@ -874,16 +892,20 @@ exports.Client.userUnsubscribed = "userUnsubscribed";
874
892
  */
875
893
  exports.Client.userUpdated = "userUpdated";
876
894
  /**
877
- * Fired when the state of the client has been changed.
895
+ * Fired when the client has completed initialization successfully.
896
+ * @event
897
+ */
898
+ exports.Client.initialized = "initialized";
899
+ /**
900
+ * Fired when the client initialization failed.
878
901
  *
879
902
  * Parameters:
880
903
  * 1. object `data` - info object provided with the event. It has the
881
- * following properties:
882
- * * {@link State} `state` - the new client state
904
+ * following property:
883
905
  * * Error? `error` - the initialization error if present
884
906
  * @event
885
907
  */
886
- exports.Client.stateChanged = "stateChanged";
908
+ exports.Client.initFailed = "initFailed";
887
909
  /**
888
910
  * Fired when the connection state of the client has been changed.
889
911
  *
@@ -1010,12 +1032,6 @@ tslib_es6.__decorate([
1010
1032
  tslib_es6.__metadata("design:paramtypes", [Array]),
1011
1033
  tslib_es6.__metadata("design:returntype", mcsClient.CancellablePromise)
1012
1034
  ], exports.Client.prototype, "getTemporaryContentUrlsForMedia", null);
1013
- tslib_es6.__decorate([
1014
- declarativeTypeValidator.validateTypesAsync("string", ["undefined", declarativeTypeValidator.pureObject]),
1015
- tslib_es6.__metadata("design:type", Function),
1016
- tslib_es6.__metadata("design:paramtypes", [String, Object]),
1017
- tslib_es6.__metadata("design:returntype", Promise)
1018
- ], exports.Client, "create", null);
1019
1035
  tslib_es6.__decorate([
1020
1036
  declarativeTypeValidator.validateTypes(declarativeTypeValidator.pureObject),
1021
1037
  tslib_es6.__metadata("design:type", Function),
@@ -1 +1 @@
1
- {"version":3,"file":"client.js","sources":["../src/client.ts"],"sourcesContent":["import { Logger } from \"./logger\";\nimport { Configuration } from \"./configuration\";\n\nimport { User, UserUpdatedEventArgs, UserUpdateReason } from \"./user\";\nimport { Network } from \"./services/network\";\n\nimport { NotificationTypes } from \"./interfaces/notification-types\";\n\nimport {\n TwilsockClient,\n InitRegistration,\n ConnectionState as TwilsockConnectionState,\n Transport,\n ConnectionError,\n} from \"twilsock\";\nimport {\n ChannelType,\n Notifications as NotificationClient,\n} from \"@twilio/notifications\";\nimport { SyncClient } from \"twilio-sync\";\nimport { McsClient } from \"@twilio/mcs-client\";\n\nimport {\n Conversation,\n Conversations,\n Conversations as ConversationsEntity,\n} from \"./data/conversations\";\n\nimport { Users } from \"./data/users\";\nimport { TypingIndicator } from \"./services/typing-indicator\";\nimport { Paginator } from \"./interfaces/paginator\";\nimport { PushNotification } from \"./push-notification\";\nimport { deepClone, parseToNumber } from \"./util\";\nimport {\n Participant,\n ParticipantUpdatedEventArgs,\n ParticipantUpdateReason,\n} from \"./participant\";\nimport {\n Message,\n MessageUpdatedEventArgs,\n MessageUpdateReason,\n} from \"./message\";\nimport { TelemetryEventDescription, TelemetryPoint } from \"twilsock\";\nimport {\n validateTypesAsync,\n validateTypes,\n literal,\n nonEmptyString,\n pureObject,\n objectSchema,\n validateConstructorTypes,\n nonEmptyArray,\n} from \"@twilio/declarative-type-validator\";\nimport { version as sdkVersion } from \"../package.json\";\nimport {\n ConversationUpdatedEventArgs,\n ConversationUpdateReason,\n} from \"./conversation\";\nimport { CommandExecutor } from \"./command-executor\";\nimport { ConfigurationResponse } from \"./interfaces/commands/configuration\";\nimport { ReplayEventEmitter } from \"@twilio/replay-event-emitter\";\nimport { JSONValue } from \"./types\";\nimport { Media } from \"./media\";\nimport { CancellablePromise } from \"@twilio/mcs-client\";\n\n/**\n * Client events.\n */\ntype ClientEvents = {\n conversationAdded: (conversation: Conversation) => void;\n conversationJoined: (conversation: Conversation) => void;\n conversationLeft: (conversation: Conversation) => void;\n conversationRemoved: (conversation: Conversation) => void;\n conversationUpdated: (data: {\n conversation: Conversation;\n updateReasons: ConversationUpdateReason[];\n }) => void;\n participantJoined: (participant: Participant) => void;\n participantLeft: (participant: Participant) => void;\n participantUpdated: (data: {\n participant: Participant;\n updateReasons: ParticipantUpdateReason[];\n }) => void;\n messageAdded: (message: Message) => void;\n messageRemoved: (message: Message) => void;\n messageUpdated: (data: {\n message: Message;\n updateReasons: MessageUpdateReason[];\n }) => void;\n tokenAboutToExpire: () => void;\n tokenExpired: () => void;\n typingEnded: (participant: Participant) => void;\n typingStarted: (participant: Participant) => void;\n pushNotification: (pushNotification: PushNotification) => void;\n userSubscribed: (user: User) => void;\n userUnsubscribed: (user: User) => void;\n userUpdated: (data: {\n user: User;\n updateReasons: UserUpdateReason[];\n }) => void;\n stateChanged: ({\n state,\n error,\n }: {\n state: State;\n error?: ConnectionError;\n }) => void;\n connectionStateChanged: (state: TwilsockConnectionState) => void;\n connectionError: (data: ConnectionError) => void;\n};\n\n/**\n * Connection state of the client. Possible values are as follows:\n * * `'connecting'` - client is offline and connection attempt is in process\n * * `'connected'` - client is online and ready\n * * `'disconnecting'` - client is going offline as disconnection is in process\n * * `'disconnected'` - client is offline and no connection attempt is in\n * process\n * * `'denied'` - client connection is denied because of invalid JWT access\n * token. User must refresh token in order to proceed\n */\ntype ConnectionState = TwilsockConnectionState;\n\n/**\n * State of the client. Possible values are as follows:\n * * `'failed'` - the client failed to initialize\n * * `'initialized'` - the client successfully initialized\n */\ntype State = \"failed\" | \"initialized\";\n\n/**\n * Notifications channel type. Possible values are as follows:\n * * `'fcm'`\n * * `'apn'`\n */\ntype NotificationsChannelType = ChannelType;\n\n/**\n * Level of logging.\n */\ntype LogLevel = \"trace\" | \"debug\" | \"info\" | \"warn\" | \"error\" | \"silent\";\n\n/**\n * Conversations client options.\n */\ninterface ClientOptions {\n /**\n * The level of logging to enable.\n */\n logLevel?: LogLevel;\n\n region?: string;\n productId?: string;\n twilsockClient?: TwilsockClient;\n transport?: Transport;\n notificationsClient?: NotificationClient;\n syncClient?: SyncClient;\n typingIndicatorTimeoutOverride?: number;\n consumptionReportIntervalOverride?: string;\n httpCacheIntervalOverride?: string;\n userInfosToSubscribeOverride?: number;\n retryWhenThrottledOverride?: boolean;\n backoffConfigOverride?: Record<string, unknown>;\n Chat?: ClientOptions;\n IPMessaging?: ClientOptions;\n Sync?: Record<string, unknown>;\n Notification?: Record<string, unknown>;\n Twilsock?: Record<string, unknown>;\n clientMetadata?: Record<string, unknown>;\n initRegistrations?: InitRegistration[];\n disableDeepClone?: boolean;\n typingUri?: string;\n apiUri?: string;\n}\n\n/**\n * Options for {@link Client.createConversation}.\n */\ninterface CreateConversationOptions {\n /**\n * Any custom attributes to attach to the conversation.\n */\n attributes?: JSONValue;\n\n /**\n * A non-unique display name of the conversation.\n */\n friendlyName?: string;\n\n /**\n * A unique identifier of the conversation.\n */\n uniqueName?: string;\n}\n\n/**\n * Client services.\n */\nclass ClientServices {\n commandExecutor!: CommandExecutor;\n twilsockClient!: TwilsockClient;\n users!: Users;\n notificationClient!: NotificationClient;\n network!: Network;\n typingIndicator!: TypingIndicator;\n syncClient!: SyncClient;\n mcsClient!: McsClient;\n transport!: Transport;\n}\n\n/**\n * A client is the starting point to the Twilio Conversations functionality.\n */\n@validateConstructorTypes(nonEmptyString, [pureObject, \"undefined\"])\nclass Client extends ReplayEventEmitter<ClientEvents> {\n /**\n * Fired when a conversation becomes visible to the client. The event is also\n * triggered when the client creates a new conversation.\n * Fired for all conversations that the client has joined.\n *\n * Parameters:\n * 1. {@link Conversation} `conversation` - the conversation in question\n * @event\n */\n public static readonly conversationAdded = \"conversationAdded\";\n\n /**\n * Fired when the client joins a conversation.\n *\n * Parameters:\n * 1. {@link Conversation} `conversation` - the conversation in question\n * @event\n */\n public static readonly conversationJoined = \"conversationJoined\";\n\n /**\n * Fired when the client leaves a conversation.\n *\n * Parameters:\n * 1. {@link Conversation} `conversation` - the conversation in question\n * @event\n */\n public static readonly conversationLeft = \"conversationLeft\";\n\n /**\n * Fired when a conversation is no longer visible to the client.\n *\n * Parameters:\n * 1. {@link Conversation} `conversation` - the conversation in question\n * @event\n */\n public static readonly conversationRemoved = \"conversationRemoved\";\n\n /**\n * Fired when the attributes or the metadata of a conversation have been\n * updated. During conversation's creation and initialization, this event\n * might be fired multiple times for same joined or created conversation as\n * new data is arriving from different sources.\n *\n * Parameters:\n * 1. object `data` - info object provided with the event. It has the\n * following properties:\n * * {@link Conversation} `conversation` - the conversation in question\n * * {@link ConversationUpdateReason}[] `updateReasons` - array of reasons\n * for the update\n * @event\n */\n public static readonly conversationUpdated = \"conversationUpdated\";\n\n /**\n * Fired when a participant has joined a conversation.\n *\n * Parameters:\n * 1. {@link Participant} `participant` - the participant in question\n * @event\n */\n public static readonly participantJoined = \"participantJoined\";\n\n /**\n * Fired when a participant has left a conversation.\n *\n * Parameters:\n * 1. {@link Participant} `participant` - the participant in question\n * @event\n */\n public static readonly participantLeft = \"participantLeft\";\n\n /**\n * Fired when a participant's fields have been updated.\n *\n * Parameters:\n * 1. object `data` - info object provided with the event. It has the\n * following properties:\n * * {@link Participant} `participant` - the participant in question\n * * {@link ParticipantUpdateReason}[] `updateReasons` - array of reasons\n * for the update\n * @event\n */\n public static readonly participantUpdated = \"participantUpdated\";\n\n /**\n * Fired when a new message has been added to the conversation on the server.\n *\n * Parameters:\n * 1. {@link Message} `message` - the message in question\n * @event\n */\n public static readonly messageAdded = \"messageAdded\";\n\n /**\n * Fired when a message is removed from the message list of a conversation.\n *\n * Parameters:\n * 1. {@link Message} `message` - the message in question\n * @event\n */\n public static readonly messageRemoved = \"messageRemoved\";\n\n /**\n * Fired when the fields of an existing message are updated with new values.\n *\n * Parameters:\n * 1. object `data` - info object provided with the event. It has the\n * following properties:\n * * {@link Message} `message` - the message in question\n * * {@link MessageUpdateReason}[] `updateReasons` - array of reasons for\n * the update\n * @event\n */\n public static readonly messageUpdated = \"messageUpdated\";\n\n /**\n * Fired when the token is about to expire and needs to be updated.\n * @event\n */\n public static readonly tokenAboutToExpire = \"tokenAboutToExpire\";\n\n /**\n * Fired when the token has expired.\n * @event\n */\n public static readonly tokenExpired = \"tokenExpired\";\n\n /**\n * Fired when a participant has stopped typing.\n *\n * Parameters:\n * 1. {@link Participant} `participant` - the participant in question\n * @event\n */\n public static readonly typingEnded = \"typingEnded\";\n\n /**\n * Fired when a participant has started typing.\n *\n * Parameters:\n * 1. {@link Participant} `participant` - the participant in question\n * @event\n */\n public static readonly typingStarted = \"typingStarted\";\n\n /**\n * Fired when the client has received (and parsed) a push notification via one\n * of the push channels (apn or fcm).\n *\n * Parameters:\n * 1. {@link PushNotification} `pushNotification` - the push notification in\n * question\n * @event\n */\n public static readonly pushNotification = \"pushNotification\";\n\n /**\n * Fired when the client has subscribed to a user.\n *\n * Parameters:\n * 1. {@link User} `user` - the user in question\n * @event\n */\n public static readonly userSubscribed = \"userSubscribed\";\n\n /**\n * Fired when the client has unsubscribed from a user.\n *\n * Parameters:\n * 1. {@link User} `user` - the user in question\n * @event\n */\n public static readonly userUnsubscribed = \"userUnsubscribed\";\n\n /**\n * Fired when the properties or the reachability status of a user have been\n * updated.\n *\n * Parameters:\n * 1. object `data` - info object provided with the event. It has the\n * following properties:\n * * {@link User} `user` - the user in question\n * * {@link UserUpdateReason}[] `updateReasons` - array of reasons for the\n * update\n * @event\n */\n public static readonly userUpdated = \"userUpdated\";\n\n /**\n * Fired when the state of the client has been changed.\n *\n * Parameters:\n * 1. object `data` - info object provided with the event. It has the\n * following properties:\n * * {@link State} `state` - the new client state\n * * Error? `error` - the initialization error if present\n * @event\n */\n public static readonly stateChanged = \"stateChanged\";\n\n /**\n * Fired when the connection state of the client has been changed.\n *\n * Parameters:\n * 1. {@link ConnectionState} `state` - the new connection state\n * @event\n */\n public static readonly connectionStateChanged = \"connectionStateChanged\";\n\n /**\n * Fired when the connection is interrupted for an unexpected reason.\n *\n * Parameters:\n * 1. object `data` - info object provided with the event. It has the\n * following properties:\n * * boolean `terminal` - Twilsock will stop connection attempts if true\n * * string `message` - the error message of the root cause\n * * number? `httpStatusCode` - http status code if available\n * * number? `errorCode` - Twilio public error code if available\n * @event\n */\n public static readonly connectionError = \"connectionError\";\n\n /**\n * Current version of the Conversations client.\n */\n public static readonly version: string = sdkVersion;\n\n /**\n * Logger instance.\n */\n private static readonly _logger = Logger.scope(\"Client\");\n\n /**\n * Supported push notification channels.\n */\n private static readonly _supportedPushChannels: NotificationsChannelType[] = [\n \"fcm\",\n \"apn\",\n ];\n\n /**\n * Supported push data fields.\n */\n private static readonly _supportedPushDataFields = {\n conversation_sid: \"conversationSid\", // string\n conversation_title: \"conversationTitle\", // string\n message_sid: \"messageSid\", // string\n message_index: \"messageIndex\", // integer\n media_count: \"mediaCount\", // integer\n media: \"media\", // object\n };\n\n /**\n * Current version of the Conversations client.\n */\n public readonly version: string = sdkVersion;\n\n /**\n * Client connection state.\n */\n public connectionState: ConnectionState = \"unknown\";\n\n /**\n * Promise that resolves on successful initialization.\n */\n private readonly _ensureReady!: Promise<void>;\n\n /**\n * Options passed to the client.\n */\n private readonly _options: Partial<ClientOptions>;\n\n /**\n * Client service objects.\n */\n private readonly _services: ClientServices;\n\n /**\n * The user of the client.\n */\n private readonly _myself: User;\n\n /**\n * Resolves the {@link Client._ensureReady} promise.\n */\n private _resolveEnsureReady!: () => void;\n\n /**\n * Rejects the {@link Client._ensureReady} promise.\n */\n private _rejectEnsureReady!: (err?: ConnectionError) => void;\n\n /**\n * The current token of the client.\n */\n private _fpaToken: string;\n\n /**\n * The constructed configuration object.\n */\n private _configuration!: Configuration;\n\n /**\n * The Conversations entity.\n */\n private _conversationsEntity!: Conversations;\n\n /**\n * Promise that resolves when initial conversations are fetched.\n */\n private _conversationsPromise!: Promise<Conversations>;\n\n /**\n * Returned Conversations instance is not yet fully initialized. Calling any\n * operations will block until it is. Use connection events to monitor when\n * client becomes fully available (connectionStateChanged with state\n * 'connected') or not available (connectionStateChange with state 'denied',\n * event tokenExpired, event connectionError).\n *\n * @param fpaToken Access token\n * @param options Options to customize the Client\n * @returns A not yet fully-initialized client.\n */\n public constructor(fpaToken: string, options: ClientOptions | null = {}) {\n super();\n\n this._fpaToken = fpaToken ?? \"\";\n this._options = options ?? {};\n\n if (!this._options.disableDeepClone) {\n let options: Partial<ClientOptions> = {\n ...this._options,\n transport: undefined,\n twilsockClient: undefined,\n };\n\n options = deepClone(options);\n options.transport = this._options.transport;\n options.twilsockClient = this._options.twilsockClient;\n\n this._options = options;\n }\n\n this._options.logLevel = this._options.logLevel ?? \"silent\";\n Client._logger.setLevel(this._options.logLevel);\n\n const productId = (this._options.productId = \"ip_messaging\");\n\n // Filling ClientMetadata\n this._options.clientMetadata = this._options.clientMetadata || {};\n\n if (!this._options.clientMetadata.hasOwnProperty(\"type\")) {\n this._options.clientMetadata.type = \"conversations\";\n }\n\n if (!this._options.clientMetadata.hasOwnProperty(\"sdk\")) {\n this._options.clientMetadata.sdk = \"JS\";\n this._options.clientMetadata.sdkv = sdkVersion;\n }\n\n // Enable session local storage for Sync\n this._options.Sync = this._options.Sync || {};\n\n if (typeof this._options.Sync.enableSessionStorage === \"undefined\") {\n this._options.Sync.enableSessionStorage = true;\n }\n\n if (this._options.region) {\n this._options.Sync.region = this._options.region;\n }\n\n if (!fpaToken) {\n throw new Error(\"A valid Twilio token should be provided\");\n }\n\n this._services = new ClientServices();\n\n this._myself = new User(\"\", \"\", null, this._services);\n\n const startTwilsock = !this._options.twilsockClient;\n\n // Create default init registrations if none were provided.\n // Otherwise, the outside party have to list all the init registrations they\n // need.\n // Init registrations passed to the Conversations client will be passed down\n // to the Sync client as well.\n if (!this._options.initRegistrations) {\n const initRegistration = new InitRegistration(productId);\n Client.populateInitRegistrations(initRegistration);\n this._options.initRegistrations = [initRegistration];\n }\n\n this._services.twilsockClient = this._options.twilsockClient =\n this._options.twilsockClient ??\n new TwilsockClient(fpaToken, productId, this._options);\n\n this._services.twilsockClient.on(\"tokenAboutToExpire\", () =>\n this.emit(\"tokenAboutToExpire\")\n );\n this._services.twilsockClient.on(\"tokenExpired\", () =>\n this.emit(\"tokenExpired\")\n );\n this._services.twilsockClient.on(\"connectionError\", (error) =>\n this.emit(\"connectionError\", error)\n );\n this._services.twilsockClient.on(\n \"stateChanged\",\n (state: ConnectionState) => {\n Client._logger.debug(\n `Handling stateChanged for ConversationsClient: new state ${state}`\n );\n if (state !== this.connectionState) {\n this.connectionState = state;\n this.emit(\"connectionStateChanged\", this.connectionState);\n }\n }\n );\n\n this._services.transport = this._options.transport = (this._options\n .transport ?? this._options.twilsockClient) as Transport;\n this._services.notificationClient = this._options.notificationsClient =\n this._options.notificationsClient ??\n new NotificationClient(fpaToken, this._options);\n this._services.syncClient = this._options.syncClient =\n this._options.syncClient ?? new SyncClient(fpaToken, this._options);\n\n const configurationOptions =\n options?.Chat || options?.IPMessaging || options || {};\n const region = configurationOptions.region || options?.region;\n const baseUrl: string =\n configurationOptions.apiUri ||\n configurationOptions.typingUri ||\n `https://aim.${region || \"us1\"}.twilio.com`;\n\n this._services.commandExecutor = new CommandExecutor(\n baseUrl,\n { transport: this._options.transport },\n productId\n );\n\n const emitFailed = (error?: ConnectionError): void => {\n this._rejectEnsureReady(error);\n this.emit(\"stateChanged\", { state: \"failed\", error });\n };\n\n this._services.twilsockClient.onceWithReplay(\"connectionError\", emitFailed);\n this._services.twilsockClient.onceWithReplay(\"disconnected\", emitFailed);\n this._services.twilsockClient.onceWithReplay(\"connected\", async () => {\n Client._logger.debug(`ConversationsClient started INITIALIZING`);\n this._services.twilsockClient.off(\"connectionError\", emitFailed);\n this._services.twilsockClient.off(\"disconnected\", emitFailed);\n try {\n const startupEvent = \"conversations.client.startup\";\n\n this._services.twilsockClient.addPartialTelemetryEvent(\n new TelemetryEventDescription(\n startupEvent,\n \"Conversations client startup\",\n new Date()\n ),\n startupEvent,\n TelemetryPoint.Start\n );\n\n await this._initialize();\n\n this._services.twilsockClient.addPartialTelemetryEvent(\n new TelemetryEventDescription(\"\", \"\", new Date()),\n startupEvent,\n TelemetryPoint.End\n );\n } catch (err) {\n // Fail ChatClient if initialization is incomplete\n this._rejectEnsureReady(err);\n this.emit(\"stateChanged\", { state: \"failed\", error: err });\n }\n });\n\n this._ensureReady = new Promise<void>((resolve, reject) => {\n this._resolveEnsureReady = resolve;\n this._rejectEnsureReady = reject;\n }).catch(() => void 0); // @todo How to process unhandled rejection here?\n\n if (startTwilsock) {\n this._services.twilsockClient.connect();\n }\n }\n\n /**\n * Information of the logged-in user. Before client initialization, returns an\n * uninitialized user. Will trigger a {@link Client.userUpdated} event after\n * initialization.\n */\n public get user(): User {\n return this._myself;\n }\n\n /**\n * Client reachability state. Throws an error if accessed before the client\n * initialization was completed.\n */\n public get reachabilityEnabled(): boolean {\n if (!this._configuration) {\n throw new Error(\n \"Reachability information could not yet be accessed as the client \" +\n \"has not yet been initialized. Subscribe to the 'stateChanged' event \" +\n \"to properly react to the client initialization.\"\n );\n }\n\n return this._configuration.reachabilityEnabled;\n }\n\n /**\n * @deprecated Call constructor directly.\n *\n * Factory method to create a Conversations client instance.\n *\n * The factory method will automatically trigger connection.\n * Do not use it if you need finer-grained control.\n *\n * Since this method returns an already-initialized client, some of the events\n * will be lost because they happen *before* the initialization. It is\n * recommended that `client.onWithReplay` is used as opposed to `client.on`\n * for subscribing to client events. The `client.onWithReplay` will re-emit\n * the most recent value for a given event if it emitted before the\n * subscription.\n *\n * @param token Access token.\n * @param options Options to customize the client.\n * @returns Returns a fully initialized client.\n */\n @validateTypesAsync(\"string\", [\"undefined\", pureObject])\n public static async create(\n token: string,\n options?: ClientOptions | null\n ): Promise<Client> {\n // The logic is as follows:\n // - If twilsock is not passed in, then the ConversationsClient constructor will call twilsock.connect() by itself\n // and we do not need to do it here.\n // - If twilsock was passed in from the outside, but customer called ConversationsClient.create() then they are\n // using an obsolete workflow and the startup sequence will never complete.\n if (options?.twilsockClient) {\n throw new Error(\n \"Obsolete usage of ConversationsClient.create() \" +\n \"factory method: if you pass twilsock from the outside then you must \" +\n \"use ConversationsClient constructor and be prepared to work with \" +\n \"uninitialized client.\"\n );\n }\n\n const client = new Client(token, options);\n await client._ensureReady;\n\n return client;\n }\n\n /**\n * Static method for push notification payload parsing. Returns parsed push as\n * a {@link PushNotification} object.\n * @param notificationPayload Push notification payload.\n */\n @validateTypes(pureObject)\n public static parsePushNotification(notificationPayload): PushNotification {\n Client._logger.debug(\n \"parsePushNotification, notificationPayload=\",\n notificationPayload\n );\n\n // APNS specifics\n if (typeof notificationPayload.aps !== \"undefined\") {\n if (!notificationPayload.twi_message_type) {\n throw new Error(\n \"Provided push notification payload does not contain Programmable Chat push notification type\"\n );\n }\n\n const data = Client._parsePushNotificationChatData(notificationPayload);\n\n const apsPayload = notificationPayload.aps;\n let body: string | null;\n let title: string | null = null;\n if (typeof apsPayload.alert === \"string\") {\n body = apsPayload.alert || null;\n } else {\n body = apsPayload.alert.body || null;\n title = apsPayload.alert.title || null;\n }\n\n return new PushNotification({\n title,\n body,\n sound: apsPayload.sound || null,\n badge: apsPayload.badge || null,\n action: apsPayload.category || null,\n type: notificationPayload.twi_message_type,\n data: data,\n });\n }\n\n // FCM specifics\n if (typeof notificationPayload.data !== \"undefined\") {\n const dataPayload = notificationPayload.data;\n if (!dataPayload.twi_message_type) {\n throw new Error(\n \"Provided push notification payload does not contain Programmable Chat push notification type\"\n );\n }\n\n const data = Client._parsePushNotificationChatData(\n notificationPayload.data\n );\n return new PushNotification({\n title: dataPayload.twi_title || null,\n body: dataPayload.twi_body || null,\n sound: dataPayload.twi_sound || null,\n badge: null,\n action: dataPayload.twi_action || null,\n type: dataPayload.twi_message_type,\n data: data,\n });\n }\n\n throw new Error(\n \"Provided push notification payload is not Programmable Chat notification\"\n );\n }\n\n /**\n * Static method for parsing push notification chat data.\n * @param data Data to parse\n */\n private static _parsePushNotificationChatData(\n data: Record<string, unknown>\n ): Record<string, unknown> {\n const result: Record<string, unknown> = {};\n\n for (const key in Client._supportedPushDataFields) {\n const value = data[key];\n if (typeof value === \"undefined\" || value === null) {\n continue;\n }\n\n if (key === \"message_index\" || key === \"media_count\") {\n const number = parseToNumber(value);\n if (number !== null) {\n result[Client._supportedPushDataFields[key]] = number;\n }\n continue;\n }\n\n if (key === \"media\") {\n if (typeof value === \"string\") {\n try {\n result[Client._supportedPushDataFields[key]] = JSON.parse(value);\n } catch {\n Client._logger.debug(\"Media message notification parsing error\");\n }\n }\n continue;\n }\n\n result[Client._supportedPushDataFields[key]] = value;\n }\n\n return result;\n }\n\n /**\n * Populate the client with init registrations.\n * @param reg The init registration to populate.\n */\n public static populateInitRegistrations(reg: InitRegistration) {\n reg.populateInitRegistrations([NotificationTypes.TYPING_INDICATOR]);\n SyncClient.populateInitRegistrations(reg);\n }\n\n /**\n * Gracefully shut down the client.\n */\n public async shutdown(): Promise<void> {\n await this._ensureReady;\n await this._services.twilsockClient.disconnect();\n }\n\n /**\n * Update the token used by the client and re-register with the Conversations services.\n * @param token New access token.\n */\n @validateTypesAsync(nonEmptyString)\n public async updateToken(token: string): Promise<Client> {\n await this._ensureReady;\n Client._logger.info(\"updateToken\");\n\n if (this._fpaToken === token) {\n return this;\n }\n\n await this._services.twilsockClient.updateToken(token);\n await this._services.notificationClient.updateToken(token);\n await this._services.mcsClient.updateToken(token);\n this._fpaToken = token;\n\n return this;\n }\n\n /**\n * Get a known conversation by its SID.\n * @param conversationSid Conversation sid\n */\n @validateTypesAsync(nonEmptyString)\n public async getConversationBySid(\n conversationSid: string\n ): Promise<Conversation> {\n await this._ensureReady;\n await this._conversationsEntity.myConversationsRead.promise;\n\n const conversation = await this._conversationsEntity.getConversation(\n conversationSid\n );\n\n if (!conversation) {\n throw new Error(\n `Conversation with SID ${conversationSid} was not found.`\n );\n }\n\n return conversation;\n }\n\n /**\n * Peek a conversation by its SID.\n * @param conversationSid Conversation sid\n * @internal\n */\n @validateTypesAsync(nonEmptyString)\n public async peekConversationBySid(\n conversationSid: string\n ): Promise<Conversation> {\n await this._ensureReady;\n\n const conversation = await this._conversationsEntity.peekConversation(\n conversationSid\n );\n\n if (!conversation) {\n throw new Error(\n `Conversation with SID ${conversationSid} was not found.`\n );\n }\n\n return conversation;\n }\n\n /**\n * Get a known conversation by its unique identifier name.\n * @param uniqueName The unique identifier name of the conversation.\n */\n @validateTypesAsync(nonEmptyString)\n public async getConversationByUniqueName(\n uniqueName: string\n ): Promise<Conversation> {\n await this._ensureReady;\n await this._conversationsEntity.myConversationsRead.promise;\n const conversation =\n await this._conversationsEntity.getConversationByUniqueName(uniqueName);\n\n if (!conversation) {\n throw new Error(\n `Conversation with unique name ${uniqueName} was not found.`\n );\n }\n\n return conversation;\n }\n\n /**\n * Get the current list of all the subscribed conversations.\n */\n public async getSubscribedConversations(): Promise<Paginator<Conversation>> {\n await this._ensureReady;\n return this._conversationsPromise.then((conversations) =>\n conversations.getConversations()\n );\n }\n\n /**\n * Create a conversation on the server and subscribe to its events.\n * The default is a conversation with an empty friendly name.\n * @param options Options for the conversation.\n */\n @validateTypesAsync([\n \"undefined\",\n objectSchema(\"conversation options\", {\n friendlyName: [\"string\", \"undefined\"],\n isPrivate: [\"boolean\", \"undefined\"],\n uniqueName: [\"string\", \"undefined\"],\n }),\n ])\n public async createConversation(\n options?: CreateConversationOptions\n ): Promise<Conversation> {\n await this._ensureReady;\n options = options || {};\n return this._conversationsPromise.then((conversationsEntity) =>\n conversationsEntity.addConversation(options)\n );\n }\n\n /**\n * Register for push notifications.\n * @param channelType Channel type.\n * @param registrationId Push notification ID provided by the FCM/APNS service\n * on the platform.\n */\n @validateTypesAsync(literal(\"fcm\", \"apn\"), \"string\")\n public async setPushRegistrationId(\n channelType: NotificationsChannelType,\n registrationId: string\n ): Promise<void> {\n await this._ensureReady;\n this._subscribeToPushNotifications(channelType);\n this._services.notificationClient.setPushRegistrationId(\n channelType,\n registrationId\n );\n await this._services.notificationClient.commitChanges(); // Committing before this point is useless because we have no push id\n }\n\n /**\n * Unregister from push notifications.\n * @param channelType Channel type.\n * @deprecated Use removePushRegistrations() instead.\n */\n @validateTypesAsync(literal(\"fcm\", \"apn\"))\n public async unsetPushRegistrationId(\n channelType: NotificationsChannelType\n ): Promise<void> {\n await this._ensureReady;\n this._unsubscribeFromPushNotifications(channelType);\n await this._services.notificationClient.commitChanges();\n }\n\n /**\n * Clear existing registrations directly using provided device token.\n * This is useful to ensure stopped subscriptions without resubscribing.\n *\n * This function goes completely beside the state machine and removes all\n * registrations.\n * Use with caution: if it races with current state machine operations,\n * madness will ensue.\n *\n * @param channelType Channel type.\n * @param registrationId Push notification ID provided by the FCM/APNS service\n * on the platform.\n */\n @validateTypesAsync(literal(\"fcm\", \"apn\"), nonEmptyString)\n public async removePushRegistrations(\n channelType: ChannelType,\n registrationId: string\n ): Promise<void> {\n // do not await this._ensureReady() here - it could be called at any moment\n await this._services.notificationClient.removeRegistrations(\n channelType,\n registrationId\n );\n }\n\n /**\n * Current version of the Conversations client.\n */\n public parsePushNotification = Client.parsePushNotification;\n\n /**\n * Handle push notification payload parsing and emit the\n * {@link Client.pushNotification} event on this {@link Client} instance.\n * @param notificationPayload Push notification payload\n */\n @validateTypesAsync(pureObject)\n public async handlePushNotification(notificationPayload): Promise<void> {\n await this._ensureReady;\n Client._logger.debug(\n \"handlePushNotification, notificationPayload=\",\n notificationPayload\n );\n this.emit(\n \"pushNotification\",\n Client.parsePushNotification(notificationPayload)\n );\n }\n\n /**\n * Gets a user with the given identity. If it's in the subscribed list, then\n * return the user object from it;\n * if not, then subscribe and add user to the subscribed list.\n * @param identity Identity of the user.\n * @returns A fully initialized user.\n */\n @validateTypesAsync(nonEmptyString)\n public async getUser(identity: string): Promise<User> {\n await this._ensureReady;\n return this._services.users.getUser(identity);\n }\n\n /**\n * Get a list of subscribed user objects.\n */\n public async getSubscribedUsers(): Promise<Array<User>> {\n await this._ensureReady;\n return this._services.users.getSubscribedUsers();\n }\n\n /**\n * Get content URLs for all media attachments in the given set of media sids\n * using a single operation.\n * @param mediaSids Set of media sids to query for the content URL.\n */\n @validateTypesAsync(nonEmptyArray(\"strings\", \"string\"))\n public getTemporaryContentUrlsForMediaSids(\n mediaSids: string[]\n ): CancellablePromise<Map<string, string>> {\n return new CancellablePromise(async (resolve, reject, onCancel) => {\n if (!this._services.mcsClient || !mediaSids) {\n reject(new Error(\"Media Content Service is unavailable\"));\n return;\n }\n\n const request =\n this._services.mcsClient.mediaSetGetContentUrls(mediaSids);\n\n onCancel(() => {\n request.cancel();\n });\n\n try {\n const urls = await request;\n resolve(urls);\n } catch (e) {\n reject(e);\n }\n });\n }\n\n /**\n * Get content URLs for all media attachments in the given set using a single\n * operation.\n * @param contentSet Set of media attachments to query content URLs.\n */\n @validateTypesAsync(nonEmptyArray(\"media\", Media))\n public getTemporaryContentUrlsForMedia(\n contentSet: Media[]\n ): CancellablePromise<Map<string, string>> {\n // We ignore existing mcsMedia members of each of the media entries.\n // Instead, we just collect their sids and pull new descriptors from a\n // mediaSet GET endpoint.\n const sids = contentSet.map((m) => m.sid);\n return this.getTemporaryContentUrlsForMediaSids(sids);\n }\n\n /**\n * Initialize the client.\n */\n private async _initialize() {\n const configurationResponse =\n await this._services.commandExecutor.fetchResource<\n void,\n ConfigurationResponse\n >(\"Client/v2/Configuration\");\n\n this._configuration = new Configuration(\n this._options as ClientOptions,\n configurationResponse,\n Client._logger\n );\n\n this._myself._resolveInitialization(\n this._configuration,\n this._configuration.userIdentity,\n this._configuration.userInfo,\n true\n );\n\n this._services.typingIndicator = new TypingIndicator(\n this.getConversationBySid.bind(this),\n this._configuration,\n this._services\n );\n this._services.network = new Network(this._configuration, this._services);\n\n this._services.users = new Users(\n this._myself,\n this._configuration,\n this._services\n );\n this._services.users.on(\"userSubscribed\", (user) => {\n this.emit(\"userSubscribed\", user);\n });\n this._services.users.on(\"userUpdated\", (args: UserUpdatedEventArgs) =>\n this.emit(\"userUpdated\", args)\n );\n this._services.users.on(\"userUnsubscribed\", (user) => {\n this.emit(\"userUnsubscribed\", user);\n });\n\n this._conversationsEntity = new ConversationsEntity(\n this._configuration,\n this._services\n );\n\n this._conversationsEntity.on(\"conversationAdded\", (conversation) => {\n this.emit(\"conversationAdded\", conversation);\n });\n this._conversationsEntity.on(\"conversationRemoved\", (conversation) => {\n this.emit(\"conversationRemoved\", conversation);\n });\n this._conversationsEntity.on(\"conversationJoined\", (conversation) => {\n this.emit(\"conversationJoined\", conversation);\n });\n this._conversationsEntity.on(\"conversationLeft\", (conversation) => {\n this.emit(\"conversationLeft\", conversation);\n });\n this._conversationsEntity.on(\n \"conversationUpdated\",\n (args: ConversationUpdatedEventArgs) =>\n this.emit(\"conversationUpdated\", args)\n );\n\n this._conversationsEntity.on(\"participantJoined\", (participant) => {\n this.emit(\"participantJoined\", participant);\n });\n this._conversationsEntity.on(\"participantLeft\", (participant) => {\n this.emit(\"participantLeft\", participant);\n });\n this._conversationsEntity.on(\n \"participantUpdated\",\n (args: ParticipantUpdatedEventArgs) =>\n this.emit(\"participantUpdated\", args)\n );\n\n this._conversationsEntity.on(\"messageAdded\", (message) =>\n this.emit(\"messageAdded\", message)\n );\n this._conversationsEntity.on(\n \"messageUpdated\",\n (args: MessageUpdatedEventArgs) => this.emit(\"messageUpdated\", args)\n );\n this._conversationsEntity.on(\"messageRemoved\", (message) =>\n this.emit(\"messageRemoved\", message)\n );\n\n this._conversationsEntity.on(\"typingStarted\", (participant) =>\n this.emit(\"typingStarted\", participant)\n );\n this._conversationsEntity.on(\"typingEnded\", (participant) =>\n this.emit(\"typingEnded\", participant)\n );\n\n this._conversationsPromise = this._conversationsEntity\n .fetchConversations()\n .then(() => this._conversationsEntity)\n .catch((error) => {\n throw error;\n });\n\n await this._services.users.myself._ensureFetched();\n\n Client._supportedPushChannels.forEach((channelType) =>\n this._subscribeToPushNotifications(channelType)\n );\n this._services.typingIndicator.initialize();\n\n this._services.mcsClient = new McsClient(\n this._fpaToken,\n this._configuration.links.mediaService,\n this._configuration.links.mediaSetService,\n {\n ...this._options,\n transport: undefined,\n }\n );\n\n this._resolveEnsureReady();\n this.emit(\"stateChanged\", { state: \"initialized\" });\n }\n\n /**\n * Subscribe to push notifications.\n * @param channelType The channel type to subscribe to.\n */\n private _subscribeToPushNotifications(channelType: NotificationsChannelType) {\n [\n NotificationTypes.NEW_MESSAGE,\n NotificationTypes.ADDED_TO_CONVERSATION,\n NotificationTypes.REMOVED_FROM_CONVERSATION,\n NotificationTypes.TYPING_INDICATOR,\n NotificationTypes.CONSUMPTION_UPDATE,\n ].forEach((messageType) => {\n this._services.notificationClient.subscribe(channelType, messageType);\n });\n }\n\n /**\n * Unsubscribe from push notifications.\n * @param channelType The channel type to unsubscribe from.\n */\n private _unsubscribeFromPushNotifications(\n channelType: NotificationsChannelType\n ) {\n [\n NotificationTypes.NEW_MESSAGE,\n NotificationTypes.ADDED_TO_CONVERSATION,\n NotificationTypes.REMOVED_FROM_CONVERSATION,\n NotificationTypes.TYPING_INDICATOR,\n NotificationTypes.CONSUMPTION_UPDATE,\n ].forEach((messageType) => {\n this._services.notificationClient.unsubscribe(channelType, messageType);\n });\n }\n}\n\nexport {\n Client,\n State,\n ConnectionState,\n NotificationsChannelType,\n LogLevel,\n ClientOptions,\n CreateConversationOptions,\n};\n"],"names":["Client","ReplayEventEmitter","sdkVersion","deepClone","User","InitRegistration","TwilsockClient","NotificationClient","SyncClient","CommandExecutor","TelemetryEventDescription","TelemetryPoint","PushNotification","parseToNumber","NotificationTypes","CancellablePromise","Configuration","TypingIndicator","Network","Users","ConversationsEntity","McsClient","Logger","__decorate","validateTypesAsync","nonEmptyString","objectSchema","literal","pureObject","nonEmptyArray","Media","validateTypes","validateConstructorTypes"],"mappings":"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"}
1
+ {"version":3,"file":"client.js","sources":["../src/client.ts"],"sourcesContent":["import { Logger } from \"./logger\";\nimport { Configuration } from \"./configuration\";\n\nimport { User, UserUpdatedEventArgs, UserUpdateReason } from \"./user\";\nimport { Network } from \"./services/network\";\n\nimport { NotificationTypes } from \"./interfaces/notification-types\";\n\nimport { TwilsockClient, InitRegistration } from \"twilsock\";\nimport {\n ChannelType,\n Notifications as NotificationClient,\n} from \"@twilio/notifications\";\nimport { SyncClient } from \"twilio-sync\";\nimport { McsClient } from \"@twilio/mcs-client\";\n\nimport {\n Conversation,\n Conversations,\n Conversations as ConversationsEntity,\n} from \"./data/conversations\";\n\nimport { Users } from \"./data/users\";\nimport { TypingIndicator } from \"./services/typing-indicator\";\nimport { Paginator } from \"./interfaces/paginator\";\nimport { PushNotification } from \"./push-notification\";\nimport { deepClone, parseToNumber } from \"./util\";\nimport {\n Participant,\n ParticipantUpdatedEventArgs,\n ParticipantUpdateReason,\n} from \"./participant\";\nimport {\n Message,\n MessageUpdatedEventArgs,\n MessageUpdateReason,\n} from \"./message\";\nimport {\n validateTypesAsync,\n validateTypes,\n literal,\n nonEmptyString,\n pureObject,\n objectSchema,\n validateConstructorTypes,\n nonEmptyArray,\n} from \"@twilio/declarative-type-validator\";\nimport { version as sdkVersion } from \"../package.json\";\nimport {\n ConversationUpdatedEventArgs,\n ConversationUpdateReason,\n} from \"./conversation\";\nimport { CommandExecutor } from \"./command-executor\";\nimport { ConfigurationResponse } from \"./interfaces/commands/configuration\";\nimport { ReplayEventEmitter } from \"@twilio/replay-event-emitter\";\nimport { JSONValue } from \"@twilio/shared\";\nimport { Media } from \"./media\";\nimport { CancellablePromise } from \"@twilio/mcs-client\";\n\n/**\n * Client events.\n */\ntype ClientEvents = {\n conversationAdded: (conversation: Conversation) => void;\n conversationJoined: (conversation: Conversation) => void;\n conversationLeft: (conversation: Conversation) => void;\n conversationRemoved: (conversation: Conversation) => void;\n conversationUpdated: (data: {\n conversation: Conversation;\n updateReasons: ConversationUpdateReason[];\n }) => void;\n participantJoined: (participant: Participant) => void;\n participantLeft: (participant: Participant) => void;\n participantUpdated: (data: {\n participant: Participant;\n updateReasons: ParticipantUpdateReason[];\n }) => void;\n messageAdded: (message: Message) => void;\n messageRemoved: (message: Message) => void;\n messageUpdated: (data: {\n message: Message;\n updateReasons: MessageUpdateReason[];\n }) => void;\n tokenAboutToExpire: () => void;\n tokenExpired: () => void;\n typingEnded: (participant: Participant) => void;\n typingStarted: (participant: Participant) => void;\n pushNotification: (pushNotification: PushNotification) => void;\n userSubscribed: (user: User) => void;\n userUnsubscribed: (user: User) => void;\n userUpdated: (data: {\n user: User;\n updateReasons: UserUpdateReason[];\n }) => void;\n initialized: () => void;\n initFailed: ({ error }: { error?: ConnectionError }) => void;\n connectionStateChanged: (state: ConnectionState) => void;\n connectionError: (data: ConnectionError) => void;\n};\n\n/**\n * Connection state of the client. Possible values are as follows:\n * * `'connecting'` - client is offline and connection attempt is in process\n * * `'connected'` - client is online and ready\n * * `'disconnecting'` - client is going offline as disconnection is in process\n * * `'disconnected'` - client is offline and no connection attempt is in\n * process\n * * `'denied'` - client connection is denied because of invalid JWT access\n * token. User must refresh token in order to proceed\n */\ntype ConnectionState = \"disconnected\" | \"connecting\" | \"connected\";\n\n/**\n * State of the client. Possible values are as follows:\n * * `'failed'` - the client failed to initialize\n * * `'initialized'` - the client successfully initialized\n */\ntype State = \"failed\" | \"initialized\";\n\n/**\n * Notifications channel type. Possible values are as follows:\n * * `'fcm'`\n * * `'apn'`\n */\ntype NotificationsChannelType = ChannelType;\n\n/**\n * Level of logging.\n */\ntype LogLevel = \"trace\" | \"debug\" | \"info\" | \"warn\" | \"error\" | \"silent\";\n\n/**\n * Conversations client options.\n */\ninterface ClientOptions {\n /**\n * The level of logging to enable.\n */\n logLevel?: LogLevel;\n\n region?: string;\n productId?: string;\n twilsockClient?: TwilsockClient;\n transport?: TwilsockClient;\n notificationsClient?: NotificationClient;\n syncClient?: SyncClient;\n typingIndicatorTimeoutOverride?: number;\n consumptionReportIntervalOverride?: string;\n httpCacheIntervalOverride?: string;\n userInfosToSubscribeOverride?: number;\n retryWhenThrottledOverride?: boolean;\n backoffConfigOverride?: Record<string, unknown>;\n Chat?: ClientOptions;\n IPMessaging?: ClientOptions;\n Sync?: Record<string, unknown>;\n Notification?: Record<string, unknown>;\n Twilsock?: Record<string, unknown>;\n clientMetadata?: Record<string, unknown>;\n initRegistrations?: InitRegistration[];\n disableDeepClone?: boolean;\n typingUri?: string;\n apiUri?: string;\n}\n\ntype ConnectionError = {\n terminal: boolean;\n message: string;\n};\n\n/**\n * Options for {@link Client.createConversation}.\n */\ninterface CreateConversationOptions {\n /**\n * Any custom attributes to attach to the conversation.\n */\n attributes?: JSONValue;\n\n /**\n * A non-unique display name of the conversation.\n */\n friendlyName?: string;\n\n /**\n * A unique identifier of the conversation.\n */\n uniqueName?: string;\n}\n\n/**\n * Client services.\n */\nclass ClientServices {\n commandExecutor!: CommandExecutor;\n twilsockClient!: TwilsockClient;\n users!: Users;\n notificationClient!: NotificationClient;\n network!: Network;\n typingIndicator!: TypingIndicator;\n syncClient!: SyncClient;\n mcsClient!: McsClient;\n transport!: TwilsockClient;\n}\n\n/**\n * A client is the starting point to the Twilio Conversations functionality.\n */\n@validateConstructorTypes(nonEmptyString, [pureObject, \"undefined\"])\nclass Client extends ReplayEventEmitter<ClientEvents> {\n /**\n * Fired when a conversation becomes visible to the client. The event is also\n * triggered when the client creates a new conversation.\n * Fired for all conversations that the client has joined.\n *\n * Parameters:\n * 1. {@link Conversation} `conversation` - the conversation in question\n * @event\n */\n public static readonly conversationAdded = \"conversationAdded\";\n\n /**\n * Fired when the client joins a conversation.\n *\n * Parameters:\n * 1. {@link Conversation} `conversation` - the conversation in question\n * @event\n */\n public static readonly conversationJoined = \"conversationJoined\";\n\n /**\n * Fired when the client leaves a conversation.\n *\n * Parameters:\n * 1. {@link Conversation} `conversation` - the conversation in question\n * @event\n */\n public static readonly conversationLeft = \"conversationLeft\";\n\n /**\n * Fired when a conversation is no longer visible to the client.\n *\n * Parameters:\n * 1. {@link Conversation} `conversation` - the conversation in question\n * @event\n */\n public static readonly conversationRemoved = \"conversationRemoved\";\n\n /**\n * Fired when the attributes or the metadata of a conversation have been\n * updated. During conversation's creation and initialization, this event\n * might be fired multiple times for same joined or created conversation as\n * new data is arriving from different sources.\n *\n * Parameters:\n * 1. object `data` - info object provided with the event. It has the\n * following properties:\n * * {@link Conversation} `conversation` - the conversation in question\n * * {@link ConversationUpdateReason}[] `updateReasons` - array of reasons\n * for the update\n * @event\n */\n public static readonly conversationUpdated = \"conversationUpdated\";\n\n /**\n * Fired when a participant has joined a conversation.\n *\n * Parameters:\n * 1. {@link Participant} `participant` - the participant in question\n * @event\n */\n public static readonly participantJoined = \"participantJoined\";\n\n /**\n * Fired when a participant has left a conversation.\n *\n * Parameters:\n * 1. {@link Participant} `participant` - the participant in question\n * @event\n */\n public static readonly participantLeft = \"participantLeft\";\n\n /**\n * Fired when a participant's fields have been updated.\n *\n * Parameters:\n * 1. object `data` - info object provided with the event. It has the\n * following properties:\n * * {@link Participant} `participant` - the participant in question\n * * {@link ParticipantUpdateReason}[] `updateReasons` - array of reasons\n * for the update\n * @event\n */\n public static readonly participantUpdated = \"participantUpdated\";\n\n /**\n * Fired when a new message has been added to the conversation on the server.\n *\n * Parameters:\n * 1. {@link Message} `message` - the message in question\n * @event\n */\n public static readonly messageAdded = \"messageAdded\";\n\n /**\n * Fired when a message is removed from the message list of a conversation.\n *\n * Parameters:\n * 1. {@link Message} `message` - the message in question\n * @event\n */\n public static readonly messageRemoved = \"messageRemoved\";\n\n /**\n * Fired when the fields of an existing message are updated with new values.\n *\n * Parameters:\n * 1. object `data` - info object provided with the event. It has the\n * following properties:\n * * {@link Message} `message` - the message in question\n * * {@link MessageUpdateReason}[] `updateReasons` - array of reasons for\n * the update\n * @event\n */\n public static readonly messageUpdated = \"messageUpdated\";\n\n /**\n * Fired when the token is about to expire and needs to be updated.\n * @event\n */\n public static readonly tokenAboutToExpire = \"tokenAboutToExpire\";\n\n /**\n * Fired when the token has expired.\n * @event\n */\n public static readonly tokenExpired = \"tokenExpired\";\n\n /**\n * Fired when a participant has stopped typing.\n *\n * Parameters:\n * 1. {@link Participant} `participant` - the participant in question\n * @event\n */\n public static readonly typingEnded = \"typingEnded\";\n\n /**\n * Fired when a participant has started typing.\n *\n * Parameters:\n * 1. {@link Participant} `participant` - the participant in question\n * @event\n */\n public static readonly typingStarted = \"typingStarted\";\n\n /**\n * Fired when the client has received (and parsed) a push notification via one\n * of the push channels (apn or fcm).\n *\n * Parameters:\n * 1. {@link PushNotification} `pushNotification` - the push notification in\n * question\n * @event\n */\n public static readonly pushNotification = \"pushNotification\";\n\n /**\n * Fired when the client has subscribed to a user.\n *\n * Parameters:\n * 1. {@link User} `user` - the user in question\n * @event\n */\n public static readonly userSubscribed = \"userSubscribed\";\n\n /**\n * Fired when the client has unsubscribed from a user.\n *\n * Parameters:\n * 1. {@link User} `user` - the user in question\n * @event\n */\n public static readonly userUnsubscribed = \"userUnsubscribed\";\n\n /**\n * Fired when the properties or the reachability status of a user have been\n * updated.\n *\n * Parameters:\n * 1. object `data` - info object provided with the event. It has the\n * following properties:\n * * {@link User} `user` - the user in question\n * * {@link UserUpdateReason}[] `updateReasons` - array of reasons for the\n * update\n * @event\n */\n public static readonly userUpdated = \"userUpdated\";\n\n /**\n * Fired when the client has completed initialization successfully.\n * @event\n */\n public static readonly initialized = \"initialized\";\n\n /**\n * Fired when the client initialization failed.\n *\n * Parameters:\n * 1. object `data` - info object provided with the event. It has the\n * following property:\n * * Error? `error` - the initialization error if present\n * @event\n */\n public static readonly initFailed = \"initFailed\";\n\n /**\n * Fired when the connection state of the client has been changed.\n *\n * Parameters:\n * 1. {@link ConnectionState} `state` - the new connection state\n * @event\n */\n public static readonly connectionStateChanged = \"connectionStateChanged\";\n\n /**\n * Fired when the connection is interrupted for an unexpected reason.\n *\n * Parameters:\n * 1. object `data` - info object provided with the event. It has the\n * following properties:\n * * boolean `terminal` - Twilsock will stop connection attempts if true\n * * string `message` - the error message of the root cause\n * * number? `httpStatusCode` - http status code if available\n * * number? `errorCode` - Twilio public error code if available\n * @event\n */\n public static readonly connectionError = \"connectionError\";\n\n /**\n * Current version of the Conversations client.\n */\n public static readonly version: string = sdkVersion;\n\n /**\n * Logger instance.\n */\n private static readonly _logger = Logger.scope(\"Client\");\n\n /**\n * Supported push notification channels.\n */\n private static readonly _supportedPushChannels: NotificationsChannelType[] = [\n \"fcm\",\n \"apn\",\n ];\n\n /**\n * Supported push data fields.\n */\n private static readonly _supportedPushDataFields = {\n conversation_sid: \"conversationSid\", // string\n conversation_title: \"conversationTitle\", // string\n message_sid: \"messageSid\", // string\n message_index: \"messageIndex\", // integer\n media_count: \"mediaCount\", // integer\n media: \"media\", // object\n };\n\n /**\n * Current version of the Conversations client.\n */\n public readonly version: string = sdkVersion;\n\n /**\n * Client connection state.\n */\n public connectionState: ConnectionState | \"unknown\" = \"unknown\";\n\n /**\n * Promise that resolves on successful initialization.\n */\n private readonly _ensureReady!: Promise<void>;\n\n /**\n * Options passed to the client.\n */\n private readonly _options: Partial<ClientOptions>;\n\n /**\n * Client service objects.\n */\n private readonly _services: ClientServices;\n\n /**\n * The user of the client.\n */\n private readonly _myself: User;\n\n /**\n * Resolves the {@link Client._ensureReady} promise.\n */\n private _resolveEnsureReady!: () => void;\n\n /**\n * Rejects the {@link Client._ensureReady} promise.\n */\n private _rejectEnsureReady!: (err?: ConnectionError) => void;\n\n /**\n * The current token of the client.\n */\n private _fpaToken: string;\n\n /**\n * The constructed configuration object.\n */\n private _configuration!: Configuration;\n\n /**\n * The Conversations entity.\n */\n private _conversationsEntity!: Conversations;\n\n /**\n * Promise that resolves when initial conversations are fetched.\n */\n private _conversationsPromise!: Promise<Conversations>;\n\n /**\n * Returned Conversations instance is not yet fully initialized. Calling any\n * operations will block until it is. Use connection events to monitor when\n * client becomes fully available (connectionStateChanged with state\n * 'connected') or not available (connectionStateChange with state 'denied',\n * event tokenExpired, event connectionError).\n *\n * @param fpaToken Access token\n * @param options Options to customize the Client\n * @returns A not yet fully-initialized client.\n */\n public constructor(fpaToken: string, options: ClientOptions | null = {}) {\n super();\n\n this._fpaToken = fpaToken ?? \"\";\n this._options = options ?? {};\n\n if (!this._options.disableDeepClone) {\n let options: Partial<ClientOptions> = {\n ...this._options,\n transport: undefined,\n twilsockClient: undefined,\n };\n\n options = deepClone(options);\n options.transport = this._options.transport;\n options.twilsockClient = this._options.twilsockClient;\n\n this._options = options;\n }\n\n this._options.logLevel = this._options.logLevel ?? \"silent\";\n Client._logger.setLevel(this._options.logLevel);\n\n const productId = (this._options.productId = \"ip_messaging\");\n\n // Filling ClientMetadata\n this._options.clientMetadata = this._options.clientMetadata || {};\n\n if (!this._options.clientMetadata.hasOwnProperty(\"type\")) {\n this._options.clientMetadata.type = \"conversations\";\n }\n\n if (!this._options.clientMetadata.hasOwnProperty(\"sdk\")) {\n this._options.clientMetadata.sdk = \"JS\";\n this._options.clientMetadata.sdkv = sdkVersion;\n }\n\n // Enable session local storage for Sync\n this._options.Sync = this._options.Sync || {};\n\n if (typeof this._options.Sync.enableSessionStorage === \"undefined\") {\n this._options.Sync.enableSessionStorage = true;\n }\n\n if (this._options.region) {\n this._options.Sync.region = this._options.region;\n }\n\n if (!fpaToken) {\n throw new Error(\"A valid Twilio token should be provided\");\n }\n\n this._services = new ClientServices();\n\n this._myself = new User(\"\", \"\", null, this._services);\n\n const startTwilsock = !this._options.twilsockClient;\n\n // Create default init registrations if none were provided.\n // Otherwise, the outside party have to list all the init registrations they\n // need.\n // Init registrations passed to the Conversations client will be passed down\n // to the Sync client as well.\n if (!this._options.initRegistrations) {\n const initRegistration = new InitRegistration(productId);\n Client.populateInitRegistrations(initRegistration);\n this._options.initRegistrations = [initRegistration];\n }\n\n this._services.twilsockClient = this._options.twilsockClient =\n this._options.twilsockClient ??\n // todo: remove any after the release of new Twilsock\n new TwilsockClient(fpaToken, productId, this._options as any);\n\n this._services.twilsockClient.on(\"tokenAboutToExpire\", () =>\n this.emit(\"tokenAboutToExpire\")\n );\n this._services.twilsockClient.on(\"tokenExpired\", () =>\n this.emit(\"tokenExpired\")\n );\n // this._services.twilsockClient.on(\"connectionError\", (error) =>\n // this.emit(\"connectionError\", error)\n // );\n // this._services.twilsockClient.on(\n // \"stateChanged\",\n // (state: ConnectionState) => {\n\n // }\n // );\n this._services.twilsockClient.on(\"disconnected\", () => {\n Client._logger.debug(\n `Handling stateChanged for ConversationsClient: new state disconnected`\n );\n if (\"disconnected\" !== this.connectionState) {\n this.connectionState = \"disconnected\";\n this.emit(\"connectionStateChanged\", this.connectionState);\n }\n });\n this._services.twilsockClient.on(\"connecting\", () => {\n Client._logger.debug(\n `Handling stateChanged for ConversationsClient: new state connecting`\n );\n if (\"connecting\" !== this.connectionState) {\n this.connectionState = \"connecting\";\n this.emit(\"connectionStateChanged\", this.connectionState);\n }\n });\n this._services.twilsockClient.on(\"connected\", () => {\n Client._logger.debug(\n `Handling stateChanged for ConversationsClient: new state connected`\n );\n if (\"connected\" !== this.connectionState) {\n this.connectionState = \"connected\";\n this.emit(\"connectionStateChanged\", this.connectionState);\n }\n });\n\n this._services.transport = this._options.transport = (this._options\n .transport ?? this._options.twilsockClient) as TwilsockClient;\n this._services.notificationClient = this._options.notificationsClient =\n this._options.notificationsClient ??\n new NotificationClient(fpaToken, this._options);\n this._services.syncClient = this._options.syncClient =\n this._options.syncClient ??\n // TwilsockClient is different between versions 0.12.2\n // (dep of twilio-sync@3.2.2) and 0.13.1 (dep of current\n // @twilio/conversations). Thus, casting to any.\n // todo: fix sync caching and migrate to that version of sync.\n new SyncClient(fpaToken, this._options as any);\n\n const configurationOptions =\n options?.Chat || options?.IPMessaging || options || {};\n const region = configurationOptions.region || options?.region;\n const baseUrl: string =\n configurationOptions.apiUri ||\n configurationOptions.typingUri ||\n `https://aim.${region || \"us1\"}.twilio.com`;\n\n this._services.commandExecutor = new CommandExecutor(\n baseUrl,\n { transport: this._options.transport },\n productId\n );\n\n const emitFailed = (error?: ConnectionError): void => {\n this._rejectEnsureReady(error);\n this.emit(\"initFailed\", { error });\n };\n\n const emitDisconnected = () => {\n emitFailed({\n terminal: true,\n message: \"Twilsock has disconnected.\",\n });\n };\n\n // this._services.twilsockClient.once(\"connectionError\", emitFailed);\n this._services.twilsockClient.once(\"disconnected\", emitDisconnected);\n this._services.twilsockClient.once(\"connected\", async () => {\n Client._logger.debug(`ConversationsClient started INITIALIZING`);\n // this._services.twilsockClient.off(\"connectionError\", emitFailed);\n this._services.twilsockClient.off(\"disconnected\", emitDisconnected);\n try {\n const startupEvent = \"conversations.client.startup\";\n\n // this._services.twilsockClient.addPartialTelemetryEvent(\n // new TelemetryEventDescription(\n // startupEvent,\n // \"Conversations client startup\",\n // new Date()\n // ),\n // startupEvent,\n // TelemetryPoint.Start\n // );\n\n await this._initialize();\n\n // this._services.twilsockClient.addPartialTelemetryEvent(\n // new TelemetryEventDescription(\"\", \"\", new Date()),\n // startupEvent,\n // TelemetryPoint.End\n // );\n } catch (err) {\n // Fail ChatClient if initialization is incomplete\n const connectionError = {\n terminal: true,\n message: err.message,\n };\n this._rejectEnsureReady(connectionError);\n this.emit(\"initFailed\", {\n error: connectionError,\n });\n }\n });\n\n this._ensureReady = new Promise<void>((resolve, reject) => {\n this._resolveEnsureReady = resolve;\n this._rejectEnsureReady = reject;\n }).catch(() => void 0); // @todo How to process unhandled rejection here?\n\n if (startTwilsock) {\n this._services.twilsockClient.connect();\n }\n }\n\n /**\n * Information of the logged-in user. Before client initialization, returns an\n * uninitialized user. Will trigger a {@link Client.userUpdated} event after\n * initialization.\n */\n public get user(): User {\n return this._myself;\n }\n\n /**\n * Client reachability state. Throws an error if accessed before the client\n * initialization was completed.\n */\n public get reachabilityEnabled(): boolean {\n if (!this._configuration) {\n throw new Error(\n \"Reachability information could not yet be accessed as the client \" +\n \"has not yet been initialized. Subscribe to 'initialized' and \" +\n \"'initFailed' events to properly react to the client initialization.\"\n );\n }\n\n return this._configuration.reachabilityEnabled;\n }\n\n /**\n * Static method for push notification payload parsing. Returns parsed push as\n * a {@link PushNotification} object.\n * @param notificationPayload Push notification payload.\n */\n @validateTypes(pureObject)\n public static parsePushNotification(notificationPayload): PushNotification {\n Client._logger.debug(\n \"parsePushNotification, notificationPayload=\",\n notificationPayload\n );\n\n // APNS specifics\n if (typeof notificationPayload.aps !== \"undefined\") {\n if (!notificationPayload.twi_message_type) {\n throw new Error(\n \"Provided push notification payload does not contain Programmable Chat push notification type\"\n );\n }\n\n const data = Client._parsePushNotificationChatData(notificationPayload);\n\n const apsPayload = notificationPayload.aps;\n let body: string | null;\n let title: string | null = null;\n if (typeof apsPayload.alert === \"string\") {\n body = apsPayload.alert || null;\n } else {\n body = apsPayload.alert?.body || null;\n title = apsPayload.alert?.title || null;\n }\n\n return new PushNotification({\n title,\n body,\n sound: apsPayload.sound || null,\n badge: apsPayload.badge || null,\n action: apsPayload.category || null,\n type: notificationPayload.twi_message_type,\n data: data,\n });\n }\n\n // FCM specifics\n if (typeof notificationPayload.data !== \"undefined\") {\n const dataPayload = notificationPayload.data;\n if (!dataPayload.twi_message_type) {\n throw new Error(\n \"Provided push notification payload does not contain Programmable Chat push notification type\"\n );\n }\n\n const data = Client._parsePushNotificationChatData(\n notificationPayload.data\n );\n return new PushNotification({\n title: dataPayload.twi_title || null,\n body: dataPayload.twi_body || null,\n sound: dataPayload.twi_sound || null,\n badge: null,\n action: dataPayload.twi_action || null,\n type: dataPayload.twi_message_type,\n data: data,\n });\n }\n\n throw new Error(\n \"Provided push notification payload is not Programmable Chat notification\"\n );\n }\n\n /**\n * Static method for parsing push notification chat data.\n * @param data Data to parse\n */\n private static _parsePushNotificationChatData(\n data: Record<string, unknown>\n ): Record<string, unknown> {\n const result: Record<string, unknown> = {};\n\n for (const key in Client._supportedPushDataFields) {\n const value = data[key];\n if (typeof value === \"undefined\" || value === null) {\n continue;\n }\n\n if (key === \"message_index\" || key === \"media_count\") {\n const number = parseToNumber(value);\n if (number !== null) {\n result[Client._supportedPushDataFields[key]] = number;\n }\n continue;\n }\n\n if (key === \"media\") {\n if (typeof value === \"string\") {\n try {\n result[Client._supportedPushDataFields[key]] = JSON.parse(value);\n } catch {\n Client._logger.debug(\"Media message notification parsing error\");\n }\n }\n continue;\n }\n\n result[Client._supportedPushDataFields[key]] = value;\n }\n\n return result;\n }\n\n /**\n * Populate the client with init registrations.\n * @param reg The init registration to populate.\n */\n public static populateInitRegistrations(reg: InitRegistration) {\n // reg.populateInitRegistrations([NotificationTypes.TYPING_INDICATOR]);\n // SyncClient.populateInitRegistrations(reg);\n }\n\n /**\n * Gracefully shut down the client.\n */\n public async shutdown(): Promise<void> {\n await this._ensureReady;\n await this._services.twilsockClient.disconnect();\n }\n\n /**\n * Update the token used by the client and re-register with the Conversations services.\n * @param token New access token.\n */\n @validateTypesAsync(nonEmptyString)\n public async updateToken(token: string): Promise<Client> {\n await this._ensureReady;\n Client._logger.info(\"updateToken\");\n\n if (this._fpaToken === token) {\n return this;\n }\n\n await this._services.twilsockClient.updateToken(token);\n await this._services.notificationClient.updateToken(token);\n await this._services.mcsClient.updateToken(token);\n this._fpaToken = token;\n\n return this;\n }\n\n /**\n * Get a known conversation by its SID.\n * @param conversationSid Conversation sid\n */\n @validateTypesAsync(nonEmptyString)\n public async getConversationBySid(\n conversationSid: string\n ): Promise<Conversation> {\n await this._ensureReady;\n await this._conversationsEntity.myConversationsRead.promise;\n\n const conversation = await this._conversationsEntity.getConversation(\n conversationSid\n );\n\n if (!conversation) {\n throw new Error(\n `Conversation with SID ${conversationSid} was not found.`\n );\n }\n\n return conversation;\n }\n\n /**\n * Peek a conversation by its SID.\n * @param conversationSid Conversation sid\n * @internal\n */\n @validateTypesAsync(nonEmptyString)\n private async peekConversationBySid(\n conversationSid: string\n ): Promise<Conversation> {\n await this._ensureReady;\n\n const conversation = await this._conversationsEntity.peekConversation(\n conversationSid\n );\n\n if (!conversation) {\n throw new Error(\n `Conversation with SID ${conversationSid} was not found.`\n );\n }\n\n return conversation;\n }\n\n /**\n * Get a known conversation by its unique identifier name.\n * @param uniqueName The unique identifier name of the conversation.\n */\n @validateTypesAsync(nonEmptyString)\n public async getConversationByUniqueName(\n uniqueName: string\n ): Promise<Conversation> {\n await this._ensureReady;\n await this._conversationsEntity.myConversationsRead.promise;\n const conversation =\n await this._conversationsEntity.getConversationByUniqueName(uniqueName);\n\n if (!conversation) {\n throw new Error(\n `Conversation with unique name ${uniqueName} was not found.`\n );\n }\n\n return conversation;\n }\n\n /**\n * Get the current list of all the subscribed conversations.\n */\n public async getSubscribedConversations(): Promise<Paginator<Conversation>> {\n await this._ensureReady;\n return this._conversationsPromise.then((conversations) =>\n conversations.getConversations()\n );\n }\n\n /**\n * Create a conversation on the server and subscribe to its events.\n * The default is a conversation with an empty friendly name.\n * @param options Options for the conversation.\n */\n @validateTypesAsync([\n \"undefined\",\n objectSchema(\"conversation options\", {\n friendlyName: [\"string\", \"undefined\"],\n isPrivate: [\"boolean\", \"undefined\"],\n uniqueName: [\"string\", \"undefined\"],\n }),\n ])\n public async createConversation(\n options?: CreateConversationOptions\n ): Promise<Conversation> {\n await this._ensureReady;\n options = options || {};\n return this._conversationsPromise.then((conversationsEntity) =>\n conversationsEntity.addConversation(options)\n );\n }\n\n /**\n * Register for push notifications.\n * @param channelType Channel type.\n * @param registrationId Push notification ID provided by the FCM/APNS service\n * on the platform.\n */\n @validateTypesAsync(literal(\"fcm\", \"apn\"), \"string\")\n public async setPushRegistrationId(\n channelType: NotificationsChannelType,\n registrationId: string\n ): Promise<void> {\n await this._ensureReady;\n this._subscribeToPushNotifications(channelType);\n this._services.notificationClient.setPushRegistrationId(\n channelType,\n registrationId\n );\n await this._services.notificationClient.commitChanges(); // Committing before this point is useless because we have no push id\n }\n\n /**\n * Unregister from push notifications.\n * @param channelType Channel type.\n * @deprecated Use removePushRegistrations() instead.\n */\n @validateTypesAsync(literal(\"fcm\", \"apn\"))\n public async unsetPushRegistrationId(\n channelType: NotificationsChannelType\n ): Promise<void> {\n await this._ensureReady;\n this._unsubscribeFromPushNotifications(channelType);\n await this._services.notificationClient.commitChanges();\n }\n\n /**\n * Clear existing registrations directly using provided device token.\n * This is useful to ensure stopped subscriptions without resubscribing.\n *\n * This function goes completely beside the state machine and removes all\n * registrations.\n * Use with caution: if it races with current state machine operations,\n * madness will ensue.\n *\n * @param channelType Channel type.\n * @param registrationId Push notification ID provided by the FCM/APNS service\n * on the platform.\n */\n @validateTypesAsync(literal(\"fcm\", \"apn\"), nonEmptyString)\n public async removePushRegistrations(\n channelType: ChannelType,\n registrationId: string\n ): Promise<void> {\n // do not await this._ensureReady() here - it could be called at any moment\n await this._services.notificationClient.removeRegistrations(\n channelType,\n registrationId\n );\n }\n\n /**\n * Current version of the Conversations client.\n */\n public parsePushNotification = Client.parsePushNotification;\n\n /**\n * Handle push notification payload parsing and emit the\n * {@link Client.pushNotification} event on this {@link Client} instance.\n * @param notificationPayload Push notification payload\n */\n @validateTypesAsync(pureObject)\n public async handlePushNotification(notificationPayload): Promise<void> {\n await this._ensureReady;\n Client._logger.debug(\n \"handlePushNotification, notificationPayload=\",\n notificationPayload\n );\n this.emit(\n \"pushNotification\",\n Client.parsePushNotification(notificationPayload)\n );\n }\n\n /**\n * Gets a user with the given identity. If it's in the subscribed list, then\n * return the user object from it;\n * if not, then subscribe and add user to the subscribed list.\n * @param identity Identity of the user.\n * @returns A fully initialized user.\n */\n @validateTypesAsync(nonEmptyString)\n public async getUser(identity: string): Promise<User> {\n await this._ensureReady;\n return this._services.users.getUser(identity);\n }\n\n /**\n * Get a list of subscribed user objects.\n */\n public async getSubscribedUsers(): Promise<Array<User>> {\n await this._ensureReady;\n return this._services.users.getSubscribedUsers();\n }\n\n /**\n * Get content URLs for all media attachments in the given set of media sids\n * using a single operation.\n * @param mediaSids Set of media sids to query for the content URL.\n */\n @validateTypesAsync(nonEmptyArray(\"strings\", \"string\"))\n public getTemporaryContentUrlsForMediaSids(\n mediaSids: string[]\n ): CancellablePromise<Map<string, string>> {\n return new CancellablePromise(async (resolve, reject, onCancel) => {\n if (!this._services.mcsClient || !mediaSids) {\n reject(new Error(\"Media Content Service is unavailable\"));\n return;\n }\n\n const request =\n this._services.mcsClient.mediaSetGetContentUrls(mediaSids);\n\n onCancel(() => {\n request.cancel();\n });\n\n try {\n const urls = await request;\n resolve(urls);\n } catch (e) {\n reject(e);\n }\n });\n }\n\n /**\n * Get content URLs for all media attachments in the given set using a single\n * operation.\n * @param contentSet Set of media attachments to query content URLs.\n */\n @validateTypesAsync(nonEmptyArray(\"media\", Media))\n public getTemporaryContentUrlsForMedia(\n contentSet: Media[]\n ): CancellablePromise<Map<string, string>> {\n // We ignore existing mcsMedia members of each of the media entries.\n // Instead, we just collect their sids and pull new descriptors from a\n // mediaSet GET endpoint.\n const sids = contentSet.map((m) => m.sid);\n return this.getTemporaryContentUrlsForMediaSids(sids);\n }\n\n /**\n * Initialize the client.\n */\n private async _initialize() {\n const configurationResponse =\n await this._services.commandExecutor.fetchResource<\n void,\n ConfigurationResponse\n >(\"Client/v2/Configuration\");\n\n this._configuration = new Configuration(\n this._options as ClientOptions,\n configurationResponse,\n Client._logger\n );\n\n this._myself._resolveInitialization(\n this._configuration,\n this._configuration.userIdentity,\n this._configuration.userInfo,\n true\n );\n\n this._services.typingIndicator = new TypingIndicator(\n this.getConversationBySid.bind(this),\n this._configuration,\n this._services\n );\n this._services.network = new Network(this._configuration, this._services);\n\n this._services.users = new Users(\n this._myself,\n this._configuration,\n this._services\n );\n this._services.users.on(\"userSubscribed\", (user) => {\n this.emit(\"userSubscribed\", user);\n });\n this._services.users.on(\"userUpdated\", (args: UserUpdatedEventArgs) =>\n this.emit(\"userUpdated\", args)\n );\n this._services.users.on(\"userUnsubscribed\", (user) => {\n this.emit(\"userUnsubscribed\", user);\n });\n\n this._conversationsEntity = new ConversationsEntity(\n this._configuration,\n this._services\n );\n\n this._conversationsEntity.on(\"conversationAdded\", (conversation) => {\n this.emit(\"conversationAdded\", conversation);\n });\n this._conversationsEntity.on(\"conversationRemoved\", (conversation) => {\n this.emit(\"conversationRemoved\", conversation);\n });\n this._conversationsEntity.on(\"conversationJoined\", (conversation) => {\n this.emit(\"conversationJoined\", conversation);\n });\n this._conversationsEntity.on(\"conversationLeft\", (conversation) => {\n this.emit(\"conversationLeft\", conversation);\n });\n this._conversationsEntity.on(\n \"conversationUpdated\",\n (args: ConversationUpdatedEventArgs) =>\n this.emit(\"conversationUpdated\", args)\n );\n\n this._conversationsEntity.on(\"participantJoined\", (participant) => {\n this.emit(\"participantJoined\", participant);\n });\n this._conversationsEntity.on(\"participantLeft\", (participant) => {\n this.emit(\"participantLeft\", participant);\n });\n this._conversationsEntity.on(\n \"participantUpdated\",\n (args: ParticipantUpdatedEventArgs) =>\n this.emit(\"participantUpdated\", args)\n );\n\n this._conversationsEntity.on(\"messageAdded\", (message) =>\n this.emit(\"messageAdded\", message)\n );\n this._conversationsEntity.on(\n \"messageUpdated\",\n (args: MessageUpdatedEventArgs) => this.emit(\"messageUpdated\", args)\n );\n this._conversationsEntity.on(\"messageRemoved\", (message) =>\n this.emit(\"messageRemoved\", message)\n );\n\n this._conversationsEntity.on(\"typingStarted\", (participant) =>\n this.emit(\"typingStarted\", participant)\n );\n this._conversationsEntity.on(\"typingEnded\", (participant) =>\n this.emit(\"typingEnded\", participant)\n );\n\n this._conversationsPromise = this._conversationsEntity\n .fetchConversations()\n .then(() => this._conversationsEntity)\n .catch((error) => {\n throw error;\n });\n\n await this._services.users.myself._ensureFetched();\n\n Client._supportedPushChannels.forEach((channelType) =>\n this._subscribeToPushNotifications(channelType)\n );\n this._services.typingIndicator.initialize();\n\n this._services.mcsClient = new McsClient(\n this._fpaToken,\n this._configuration.links.mediaService,\n this._configuration.links.mediaSetService,\n {\n ...this._options,\n transport: undefined,\n }\n );\n\n this._resolveEnsureReady();\n this.emit(\"initialized\");\n }\n\n /**\n * Subscribe to push notifications.\n * @param channelType The channel type to subscribe to.\n */\n private _subscribeToPushNotifications(channelType: NotificationsChannelType) {\n [\n NotificationTypes.NEW_MESSAGE,\n NotificationTypes.ADDED_TO_CONVERSATION,\n NotificationTypes.REMOVED_FROM_CONVERSATION,\n NotificationTypes.TYPING_INDICATOR,\n NotificationTypes.CONSUMPTION_UPDATE,\n ].forEach((messageType) => {\n this._services.notificationClient.subscribe(channelType, messageType);\n });\n }\n\n /**\n * Unsubscribe from push notifications.\n * @param channelType The channel type to unsubscribe from.\n */\n private _unsubscribeFromPushNotifications(\n channelType: NotificationsChannelType\n ) {\n [\n NotificationTypes.NEW_MESSAGE,\n NotificationTypes.ADDED_TO_CONVERSATION,\n NotificationTypes.REMOVED_FROM_CONVERSATION,\n NotificationTypes.TYPING_INDICATOR,\n NotificationTypes.CONSUMPTION_UPDATE,\n ].forEach((messageType) => {\n this._services.notificationClient.unsubscribe(channelType, messageType);\n });\n }\n}\n\nexport {\n Client,\n State,\n ConnectionState,\n NotificationsChannelType,\n LogLevel,\n ClientOptions,\n CreateConversationOptions,\n};\n"],"names":["Client","ReplayEventEmitter","sdkVersion","deepClone","User","InitRegistration","TwilsockClient","NotificationClient","SyncClient","CommandExecutor","PushNotification","parseToNumber","CancellablePromise","Configuration","TypingIndicator","Network","Users","ConversationsEntity","McsClient","NotificationTypes","Logger","__decorate","validateTypesAsync","nonEmptyString","objectSchema","literal","pureObject","nonEmptyArray","Media","validateTypes","validateConstructorTypes"],"mappings":"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"}