matrix-js-sdk 41.5.0 → 41.6.0

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 (204) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/lib/ReEmitter.js +1 -1
  3. package/lib/ReEmitter.js.map +1 -1
  4. package/lib/ToDeviceMessageQueue.js +2 -2
  5. package/lib/ToDeviceMessageQueue.js.map +1 -1
  6. package/lib/autodiscovery.js +0 -1
  7. package/lib/autodiscovery.js.map +1 -1
  8. package/lib/client.js +112 -165
  9. package/lib/client.js.map +1 -1
  10. package/lib/common-crypto/CryptoBackend.js +0 -2
  11. package/lib/common-crypto/CryptoBackend.js.map +1 -1
  12. package/lib/content-helpers.js +3 -5
  13. package/lib/content-helpers.js.map +1 -1
  14. package/lib/content-repo.js +7 -1
  15. package/lib/content-repo.js.map +1 -1
  16. package/lib/crypto/store/indexeddb-crypto-store-backend.js +9 -11
  17. package/lib/crypto/store/indexeddb-crypto-store-backend.js.map +1 -1
  18. package/lib/crypto/store/indexeddb-crypto-store.js +0 -2
  19. package/lib/crypto/store/indexeddb-crypto-store.js.map +1 -1
  20. package/lib/crypto/store/localStorage-crypto-store.js +11 -9
  21. package/lib/crypto/store/localStorage-crypto-store.js.map +1 -1
  22. package/lib/crypto/store/memory-crypto-store.js +11 -9
  23. package/lib/crypto/store/memory-crypto-store.js.map +1 -1
  24. package/lib/crypto-api/index.js +58 -58
  25. package/lib/crypto-api/index.js.map +1 -1
  26. package/lib/embedded.js +29 -45
  27. package/lib/embedded.js.map +1 -1
  28. package/lib/extensible_events_v1/MessageEvent.js +15 -15
  29. package/lib/extensible_events_v1/MessageEvent.js.map +1 -1
  30. package/lib/extensible_events_v1/PollEndEvent.js +8 -8
  31. package/lib/extensible_events_v1/PollEndEvent.js.map +1 -1
  32. package/lib/extensible_events_v1/PollResponseEvent.js +0 -1
  33. package/lib/extensible_events_v1/PollResponseEvent.js.map +1 -1
  34. package/lib/extensible_events_v1/PollStartEvent.js +28 -28
  35. package/lib/extensible_events_v1/PollStartEvent.js.map +1 -1
  36. package/lib/feature.js +5 -1
  37. package/lib/feature.js.map +1 -1
  38. package/lib/filter-component.js +4 -1
  39. package/lib/filter-component.js.map +1 -1
  40. package/lib/filter.js +1 -3
  41. package/lib/filter.js.map +1 -1
  42. package/lib/http-api/errors.js +20 -16
  43. package/lib/http-api/errors.js.map +1 -1
  44. package/lib/http-api/fetch.js +4 -6
  45. package/lib/http-api/fetch.js.map +1 -1
  46. package/lib/http-api/refresh.js +10 -12
  47. package/lib/http-api/refresh.js.map +1 -1
  48. package/lib/interactive-auth.js +1 -11
  49. package/lib/interactive-auth.js.map +1 -1
  50. package/lib/logger.js +0 -2
  51. package/lib/logger.js.map +1 -1
  52. package/lib/matrixrtc/CallMembership.js +43 -57
  53. package/lib/matrixrtc/CallMembership.js.map +1 -1
  54. package/lib/matrixrtc/MatrixRTCSession.js +19 -24
  55. package/lib/matrixrtc/MatrixRTCSession.js.map +1 -1
  56. package/lib/matrixrtc/MatrixRTCSessionManager.js +2 -3
  57. package/lib/matrixrtc/MatrixRTCSessionManager.js.map +1 -1
  58. package/lib/matrixrtc/MembershipManager.js +23 -30
  59. package/lib/matrixrtc/MembershipManager.js.map +1 -1
  60. package/lib/matrixrtc/MembershipManagerActionScheduler.js +1 -2
  61. package/lib/matrixrtc/MembershipManagerActionScheduler.js.map +1 -1
  62. package/lib/matrixrtc/RTCEncryptionManager.js +8 -11
  63. package/lib/matrixrtc/RTCEncryptionManager.js.map +1 -1
  64. package/lib/matrixrtc/ToDeviceKeyTransport.js +4 -4
  65. package/lib/matrixrtc/ToDeviceKeyTransport.js.map +1 -1
  66. package/lib/matrixrtc/utils.js +7 -1
  67. package/lib/matrixrtc/utils.js.map +1 -1
  68. package/lib/models/MSC3089TreeSpace.js +5 -7
  69. package/lib/models/MSC3089TreeSpace.js.map +1 -1
  70. package/lib/models/beacon.js +5 -11
  71. package/lib/models/beacon.js.map +1 -1
  72. package/lib/models/device.js +0 -7
  73. package/lib/models/device.js.map +1 -1
  74. package/lib/models/event-context.js +1 -2
  75. package/lib/models/event-context.js.map +1 -1
  76. package/lib/models/event-timeline-set.js +16 -26
  77. package/lib/models/event-timeline-set.js.map +1 -1
  78. package/lib/models/event-timeline.js +8 -15
  79. package/lib/models/event-timeline.js.map +1 -1
  80. package/lib/models/event.js +20 -37
  81. package/lib/models/event.js.map +1 -1
  82. package/lib/models/invites-ignorer.js +8 -12
  83. package/lib/models/invites-ignorer.js.map +1 -1
  84. package/lib/models/poll.js +7 -13
  85. package/lib/models/poll.js.map +1 -1
  86. package/lib/models/read-receipt.js +8 -4
  87. package/lib/models/read-receipt.js.map +1 -1
  88. package/lib/models/related-relations.js +0 -2
  89. package/lib/models/related-relations.js.map +1 -1
  90. package/lib/models/relations-container.js +4 -6
  91. package/lib/models/relations-container.js.map +1 -1
  92. package/lib/models/relations.js +7 -10
  93. package/lib/models/relations.js.map +1 -1
  94. package/lib/models/room-member.js +2 -24
  95. package/lib/models/room-member.js.map +1 -1
  96. package/lib/models/room-receipts.js +25 -22
  97. package/lib/models/room-receipts.js.map +1 -1
  98. package/lib/models/room-state.js +2 -2
  99. package/lib/models/room-state.js.map +1 -1
  100. package/lib/models/room-sticky-events.js +20 -5
  101. package/lib/models/room-sticky-events.js.map +1 -1
  102. package/lib/models/room.js +82 -105
  103. package/lib/models/room.js.map +1 -1
  104. package/lib/models/thread.js +12 -57
  105. package/lib/models/thread.js.map +1 -1
  106. package/lib/models/user.js +1 -20
  107. package/lib/models/user.js.map +1 -1
  108. package/lib/oidc/authorize.js +23 -32
  109. package/lib/oidc/authorize.js.map +1 -1
  110. package/lib/oidc/tokenRefresher.js +8 -11
  111. package/lib/oidc/tokenRefresher.js.map +1 -1
  112. package/lib/pushprocessor.js +8 -5
  113. package/lib/pushprocessor.js.map +1 -1
  114. package/lib/receipt-accumulator.js +12 -3
  115. package/lib/receipt-accumulator.js.map +1 -1
  116. package/lib/rendezvous/MSC4108SignInWithQR.d.ts.map +1 -1
  117. package/lib/rendezvous/MSC4108SignInWithQR.js +10 -23
  118. package/lib/rendezvous/MSC4108SignInWithQR.js.map +1 -1
  119. package/lib/rendezvous/channels/MSC4108SecureChannel.js +5 -10
  120. package/lib/rendezvous/channels/MSC4108SecureChannel.js.map +1 -1
  121. package/lib/rendezvous/transports/MSC4108RendezvousSession.js +5 -15
  122. package/lib/rendezvous/transports/MSC4108RendezvousSession.js.map +1 -1
  123. package/lib/room-hierarchy.js +7 -12
  124. package/lib/room-hierarchy.js.map +1 -1
  125. package/lib/rust-crypto/DehydratedDeviceManager.js +2 -3
  126. package/lib/rust-crypto/DehydratedDeviceManager.js.map +1 -1
  127. package/lib/rust-crypto/KeyClaimManager.js +1 -2
  128. package/lib/rust-crypto/KeyClaimManager.js.map +1 -1
  129. package/lib/rust-crypto/OutgoingRequestProcessor.js +11 -4
  130. package/lib/rust-crypto/OutgoingRequestProcessor.js.map +1 -1
  131. package/lib/rust-crypto/OutgoingRequestsManager.js +12 -12
  132. package/lib/rust-crypto/OutgoingRequestsManager.js.map +1 -1
  133. package/lib/rust-crypto/PerSessionKeyBackupDownloader.js +3 -5
  134. package/lib/rust-crypto/PerSessionKeyBackupDownloader.js.map +1 -1
  135. package/lib/rust-crypto/RoomEncryptor.js +6 -6
  136. package/lib/rust-crypto/RoomEncryptor.js.map +1 -1
  137. package/lib/rust-crypto/backup.js +22 -16
  138. package/lib/rust-crypto/backup.js.map +1 -1
  139. package/lib/rust-crypto/device-converter.js +13 -4
  140. package/lib/rust-crypto/device-converter.js.map +1 -1
  141. package/lib/rust-crypto/index.js +1 -3
  142. package/lib/rust-crypto/index.js.map +1 -1
  143. package/lib/rust-crypto/libolm_migration.js +13 -15
  144. package/lib/rust-crypto/libolm_migration.js.map +1 -1
  145. package/lib/rust-crypto/rust-crypto.js +52 -59
  146. package/lib/rust-crypto/rust-crypto.js.map +1 -1
  147. package/lib/rust-crypto/verification.js +10 -10
  148. package/lib/rust-crypto/verification.js.map +1 -1
  149. package/lib/scheduler.js +2 -2
  150. package/lib/scheduler.js.map +1 -1
  151. package/lib/secret-storage.js +16 -10
  152. package/lib/secret-storage.js.map +1 -1
  153. package/lib/serverCapabilities.js +2 -5
  154. package/lib/serverCapabilities.js.map +1 -1
  155. package/lib/sliding-sync-sdk.js +4 -9
  156. package/lib/sliding-sync-sdk.js.map +1 -1
  157. package/lib/sliding-sync.js +4 -9
  158. package/lib/sliding-sync.js.map +1 -1
  159. package/lib/store/indexeddb-local-backend.js +13 -8
  160. package/lib/store/indexeddb-local-backend.js.map +1 -1
  161. package/lib/store/indexeddb-remote-backend.js +6 -7
  162. package/lib/store/indexeddb-remote-backend.js.map +1 -1
  163. package/lib/store/indexeddb-store-worker.js +1 -2
  164. package/lib/store/indexeddb-store-worker.js.map +1 -1
  165. package/lib/store/indexeddb.js +4 -2
  166. package/lib/store/indexeddb.js.map +1 -1
  167. package/lib/store/memory.js +0 -4
  168. package/lib/store/memory.js.map +1 -1
  169. package/lib/sync-accumulator.js +2 -4
  170. package/lib/sync-accumulator.js.map +1 -1
  171. package/lib/sync.js +36 -43
  172. package/lib/sync.js.map +1 -1
  173. package/lib/timeline-window.js +2 -6
  174. package/lib/timeline-window.js.map +1 -1
  175. package/lib/utils/decryptAESSecretStorageItem.js +5 -1
  176. package/lib/utils/decryptAESSecretStorageItem.js.map +1 -1
  177. package/lib/utils/encryptAESSecretStorageItem.js +5 -1
  178. package/lib/utils/encryptAESSecretStorageItem.js.map +1 -1
  179. package/lib/utils.js +35 -20
  180. package/lib/utils.js.map +1 -1
  181. package/lib/webrtc/call.js +13 -45
  182. package/lib/webrtc/call.js.map +1 -1
  183. package/lib/webrtc/callEventHandler.js +0 -5
  184. package/lib/webrtc/callEventHandler.js.map +1 -1
  185. package/lib/webrtc/callFeed.js +0 -15
  186. package/lib/webrtc/callFeed.js.map +1 -1
  187. package/lib/webrtc/groupCall.js +82 -89
  188. package/lib/webrtc/groupCall.js.map +1 -1
  189. package/lib/webrtc/groupCallEventHandler.js +6 -7
  190. package/lib/webrtc/groupCallEventHandler.js.map +1 -1
  191. package/lib/webrtc/mediaHandler.js +8 -15
  192. package/lib/webrtc/mediaHandler.js.map +1 -1
  193. package/lib/webrtc/stats/callStatsReportGatherer.js +2 -5
  194. package/lib/webrtc/stats/callStatsReportGatherer.js.map +1 -1
  195. package/lib/webrtc/stats/connectionStatsReportBuilder.js +5 -1
  196. package/lib/webrtc/stats/connectionStatsReportBuilder.js.map +1 -1
  197. package/lib/webrtc/stats/groupCallStats.js +3 -4
  198. package/lib/webrtc/stats/groupCallStats.js.map +1 -1
  199. package/lib/webrtc/stats/media/mediaTrackStats.js +3 -3
  200. package/lib/webrtc/stats/media/mediaTrackStats.js.map +1 -1
  201. package/lib/webrtc/stats/media/mediaTrackStatsHandler.js +1 -1
  202. package/lib/webrtc/stats/media/mediaTrackStatsHandler.js.map +1 -1
  203. package/package.json +3 -3
  204. package/src/rendezvous/MSC4108SignInWithQR.ts +2 -1
@@ -1,5 +1,4 @@
1
1
  import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
2
- import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
2
  /*
4
3
  Copyright 2023-2026 The Matrix.org Foundation C.I.C.
5
4
 
@@ -94,6 +93,11 @@ export class CallMembership {
94
93
  static equal(a, b) {
95
94
  return deepCompare(a === null || a === void 0 ? void 0 : a.membershipData, b === null || b === void 0 ? void 0 : b.membershipData);
96
95
  }
96
+
97
+ /** The parsed data from the Matrix event.
98
+ * To access checked eventId and sender from the matrixEvent.
99
+ * Class construction will fail if these values cannot get obtained. */
100
+
97
101
  /**
98
102
  * Use `parseFromEvent`.
99
103
  * Constructor should only be used by tests.
@@ -107,11 +111,6 @@ export class CallMembership {
107
111
  this.matrixEvent = matrixEvent;
108
112
  this.membershipData = membershipData;
109
113
  this.rtcBackendIdentity = rtcBackendIdentity;
110
- _defineProperty(this, "logger", void 0);
111
- /** The parsed data from the Matrix event.
112
- * To access checked eventId and sender from the matrixEvent.
113
- * Class construction will fail if these values cannot get obtained. */
114
- _defineProperty(this, "matrixEventData", void 0);
115
114
  var eventId = matrixEvent.getId();
116
115
  var sender = matrixEvent.getSender();
117
116
  if (eventId === undefined) throw new Error("parentEvent is missing eventId field");
@@ -128,10 +127,9 @@ export class CallMembership {
128
127
  return this.userId;
129
128
  }
130
129
  get userId() {
131
- var {
132
- kind,
133
- data
134
- } = this.membershipData;
130
+ var _this$membershipData = this.membershipData,
131
+ kind = _this$membershipData.kind,
132
+ data = _this$membershipData.data;
135
133
  switch (kind) {
136
134
  case MembershipKind.RTC:
137
135
  return data.member.user_id;
@@ -150,10 +148,9 @@ export class CallMembership {
150
148
  */
151
149
  get slotId() {
152
150
  var _this$logger2;
153
- var {
154
- kind,
155
- data
156
- } = this.membershipData;
151
+ var _this$membershipData2 = this.membershipData,
152
+ kind = _this$membershipData2.kind,
153
+ data = _this$membershipData2.data;
157
154
  if (data.application === "m.call") {
158
155
  switch (kind) {
159
156
  case MembershipKind.RTC:
@@ -161,7 +158,9 @@ export class CallMembership {
161
158
  case MembershipKind.Session:
162
159
  default:
163
160
  {
164
- var [application, id] = [data.application, data.call_id];
161
+ var _ref = [data.application, data.call_id],
162
+ application = _ref[0],
163
+ id = _ref[1];
165
164
 
166
165
  // INFO_SLOT_ID_LEGACY_CASE (search for all occurances of this INFO to get the full picture)
167
166
  // The spec got changed to use `"ROOM"` instead of `""` empyt string for the implicit default call.
@@ -206,10 +205,9 @@ export class CallMembership {
206
205
  }
207
206
  }
208
207
  get deviceId() {
209
- var {
210
- kind,
211
- data
212
- } = this.membershipData;
208
+ var _this$membershipData3 = this.membershipData,
209
+ kind = _this$membershipData3.kind,
210
+ data = _this$membershipData3.data;
213
211
  switch (kind) {
214
212
  case MembershipKind.RTC:
215
213
  return data.member.device_id;
@@ -231,10 +229,9 @@ export class CallMembership {
231
229
  * Parsed `slot_id` (format `{application}#{id}`) into its components (application and id).
232
230
  */
233
231
  get slotDescription() {
234
- var {
235
- kind,
236
- data
237
- } = this.membershipData;
232
+ var _this$membershipData4 = this.membershipData,
233
+ kind = _this$membershipData4.kind,
234
+ data = _this$membershipData4.data;
238
235
  if (kind === MembershipKind.RTC) {
239
236
  var id = data.slot_id.slice("".concat(data.application.type, "#").length);
240
237
  return {
@@ -258,10 +255,9 @@ export class CallMembership {
258
255
  * May contain extra keys specific to the application.
259
256
  */
260
257
  get applicationData() {
261
- var {
262
- kind,
263
- data
264
- } = this.membershipData;
258
+ var _this$membershipData5 = this.membershipData,
259
+ kind = _this$membershipData5.kind,
260
+ data = _this$membershipData5.data;
265
261
  switch (kind) {
266
262
  case MembershipKind.RTC:
267
263
  return data.application;
@@ -278,10 +274,9 @@ export class CallMembership {
278
274
 
279
275
  /** @deprecated scope is not used and will be removed in future versions. replaced by application specific types.*/
280
276
  get scope() {
281
- var {
282
- kind,
283
- data
284
- } = this.membershipData;
277
+ var _this$membershipData6 = this.membershipData,
278
+ kind = _this$membershipData6.kind,
279
+ data = _this$membershipData6.data;
285
280
  switch (kind) {
286
281
  case MembershipKind.RTC:
287
282
  return undefined;
@@ -310,10 +305,9 @@ export class CallMembership {
310
305
  // the createdTs behaves equivalent to the membershipID.
311
306
  // we only need the field for the legacy member events where we needed to update them
312
307
  // synapse ignores sending state events if they have the same content.
313
- var {
314
- kind,
315
- data
316
- } = this.membershipData;
308
+ var _this$membershipData7 = this.membershipData,
309
+ kind = _this$membershipData7.kind,
310
+ data = _this$membershipData7.data;
317
311
  switch (kind) {
318
312
  case "rtc":
319
313
  return data.member.id;
@@ -335,10 +329,9 @@ export class CallMembership {
335
329
  }
336
330
  createdTs() {
337
331
  var _data$created_ts;
338
- var {
339
- kind,
340
- data
341
- } = this.membershipData;
332
+ var _this$membershipData8 = this.membershipData,
333
+ kind = _this$membershipData8.kind,
334
+ data = _this$membershipData8.data;
342
335
  switch (kind) {
343
336
  case MembershipKind.RTC:
344
337
  // TODO we need to read the referenced (relation) event if available to get the real created_ts
@@ -355,10 +348,9 @@ export class CallMembership {
355
348
  */
356
349
  getAbsoluteExpiry() {
357
350
  var _data$expires;
358
- var {
359
- kind,
360
- data
361
- } = this.membershipData;
351
+ var _this$membershipData9 = this.membershipData,
352
+ kind = _this$membershipData9.kind,
353
+ data = _this$membershipData9.data;
362
354
  switch (kind) {
363
355
  case MembershipKind.RTC:
364
356
  return undefined;
@@ -374,9 +366,7 @@ export class CallMembership {
374
366
  * @deprecated Not used by RTC events.
375
367
  */
376
368
  getMsUntilExpiry() {
377
- var {
378
- kind
379
- } = this.membershipData;
369
+ var kind = this.membershipData.kind;
380
370
  if (kind === MembershipKind.Session) {
381
371
  var absExpiry = this.getAbsoluteExpiry();
382
372
  if (absExpiry) {
@@ -393,9 +383,7 @@ export class CallMembership {
393
383
  * @returns true if the membership has expired, otherwise false
394
384
  */
395
385
  isExpired() {
396
- var {
397
- kind
398
- } = this.membershipData;
386
+ var kind = this.membershipData.kind;
399
387
  switch (kind) {
400
388
  case MembershipKind.RTC:
401
389
  return false;
@@ -423,10 +411,9 @@ export class CallMembership {
423
411
  * @returns The transport this membership uses to publish media or undefined if no transport is available.
424
412
  */
425
413
  getTransport(oldestMembership) {
426
- var {
427
- kind,
428
- data
429
- } = this.membershipData;
414
+ var _this$membershipData0 = this.membershipData,
415
+ kind = _this$membershipData0.kind,
416
+ data = _this$membershipData0.data;
430
417
  switch (kind) {
431
418
  case MembershipKind.RTC:
432
419
  return data.rtc_transports[0];
@@ -453,10 +440,9 @@ export class CallMembership {
453
440
  * Or the value of the `foci_preferred` field for legacy session memberships (m.call.member).
454
441
  */
455
442
  get transports() {
456
- var {
457
- kind,
458
- data
459
- } = this.membershipData;
443
+ var _this$membershipData1 = this.membershipData,
444
+ kind = _this$membershipData1.kind,
445
+ data = _this$membershipData1.data;
460
446
  switch (kind) {
461
447
  case MembershipKind.RTC:
462
448
  return data.rtc_transports;
@@ -1 +1 @@
1
- {"version":3,"file":"CallMembership.js","names":["deepCompare","logger","computeSlotId","slotIdToDescription","checkRtcMembershipData","computeRtcIdentityRaw","checkSessionsMembershipData","MatrixRTCMembershipParseError","EventType","DEFAULT_EXPIRE_DURATION","MembershipKind","CallMembership","membershipDataFromMatrixEvent","matrixEvent","sender","getSender","evType","getType","data","getContent","undefined","Error","RTCMembership","kind","RTC","GroupCallMemberPrefix","Session","concat","ex","debug","parseFromEvent","_this","_asyncToGenerator","membershipData","rtcBackendIdentity","member","user_id","device_id","id","equal","a","b","constructor","_defineProperty","eventId","getId","getChild","deviceId","matrixEventData","userId","slotId","_this$logger2","application","slot_id","call_id","compatibilityAdaptedId","_this$logger","info","callIntent","intent","applicationData","warn","slotDescription","slice","type","length","scope","memberId","_data$membershipID","membershipID","createdTs","_data$created_ts","getTs","created_ts","getAbsoluteExpiry","_data$expires","expires","getMsUntilExpiry","absExpiry","Date","now","isExpired","getTransport","oldestMembership","rtc_transports","focus_active","focus_selection","foci_preferred","transports"],"sources":["../../src/matrixrtc/CallMembership.ts"],"sourcesContent":["/*\nCopyright 2023-2026 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { deepCompare } from \"../utils.ts\";\nimport { type RTCCallIntent, type Transport, type SlotDescription } from \"./types.ts\";\nimport { type MatrixEvent } from \"../models/event.ts\";\nimport { type Logger, logger } from \"../logger.ts\";\nimport { computeSlotId, slotIdToDescription } from \"./utils.ts\";\nimport {\n checkRtcMembershipData,\n computeRtcIdentityRaw,\n type RtcMembershipData,\n checkSessionsMembershipData,\n type SessionMembershipData,\n MatrixRTCMembershipParseError,\n} from \"./membershipData/index.ts\";\nimport { EventType } from \"../@types/event.ts\";\n\n/**\n * The default duration in milliseconds that a membership is considered valid for.\n * Ordinarily the client responsible for the session will update the membership before it expires.\n * We use this duration as the fallback case where stale sessions are present for some reason.\n */\nexport const DEFAULT_EXPIRE_DURATION = 1000 * 60 * 60 * 4;\n\n/**\n * Describes the source event type that provided the membership data.\n */\nenum MembershipKind {\n /**\n * The modern MSC4143 format event.\n */\n RTC = \"rtc\",\n /**\n * The legacy call event type.\n */\n Session = \"session\",\n}\n\ntype MembershipData =\n | { kind: MembershipKind.RTC; data: RtcMembershipData }\n | { kind: MembershipKind.Session; data: SessionMembershipData };\n\ntype LimitedEvent = Pick<MatrixEvent, \"getId\" | \"getSender\" | \"getTs\" | \"getType\" | \"getContent\">;\n// TODO: Rename to RtcMembership once we removed the legacy SessionMembership is removed, to avoid confusion.\nexport class CallMembership {\n /**\n * Parse the membershipdata from a call membership event.\n * @param matrixEvent The Matrix event to read.\n * @returns MembershipData in either MembershipKind.RTC or MembershipKind.Session format.\n * @throws If the content is neither format.\n */\n public static membershipDataFromMatrixEvent(matrixEvent: LimitedEvent): MembershipData {\n const sender = matrixEvent.getSender();\n const evType = matrixEvent.getType();\n const data = matrixEvent.getContent();\n if (sender === undefined) throw new Error(\"matrixEvent is missing sender field\");\n try {\n // Event types are strictly checked here.\n if (evType === EventType.RTCMembership && checkRtcMembershipData(data, sender)) {\n return { kind: MembershipKind.RTC, data };\n } else if (evType === EventType.GroupCallMemberPrefix && checkSessionsMembershipData(data)) {\n return { kind: MembershipKind.Session, data };\n } else {\n throw Error(`'${evType} is not a known call membership type`);\n }\n } catch (ex) {\n if (ex instanceof MatrixRTCMembershipParseError) {\n logger.debug(\"CallMembership.MatrixRTCMembershipParseError provided invalid data\", data);\n }\n throw ex;\n }\n }\n\n /**\n * Parse the contents of a MatrixEvent and create a CallMembership instance.\n * @param matrixEvent The Matrix event to read.\n */\n public static async parseFromEvent(matrixEvent: LimitedEvent): Promise<CallMembership> {\n const membershipData: MembershipData = this.membershipDataFromMatrixEvent(matrixEvent);\n const rtcBackendIdentity =\n membershipData.kind === MembershipKind.RTC\n ? await computeRtcIdentityRaw(\n membershipData.data.member.user_id,\n membershipData.data.member.device_id,\n membershipData.data.member.id,\n )\n : `${matrixEvent.getSender()}:${membershipData.data.device_id}`;\n return new CallMembership(matrixEvent, membershipData, rtcBackendIdentity);\n }\n\n public static equal(a?: CallMembership, b?: CallMembership): boolean {\n return deepCompare(a?.membershipData, b?.membershipData);\n }\n\n private logger: Logger;\n\n /** The parsed data from the Matrix event.\n * To access checked eventId and sender from the matrixEvent.\n * Class construction will fail if these values cannot get obtained. */\n private readonly matrixEventData: { eventId: string; sender: string };\n\n /**\n * Use `parseFromEvent`.\n * Constructor should only be used by tests.\n * @private\n * @param matrixEvent\n * @param membershipData\n * @param rtcBackendIdentity\n */\n public constructor(\n /** The Matrix event that this membership is based on */\n private readonly matrixEvent: LimitedEvent,\n private readonly membershipData: MembershipData,\n public readonly rtcBackendIdentity: string,\n ) {\n const eventId = matrixEvent.getId();\n const sender = matrixEvent.getSender();\n\n if (eventId === undefined) throw new Error(\"parentEvent is missing eventId field\");\n if (sender === undefined) throw new Error(\"parentEvent is missing sender field\");\n\n this.logger = logger.getChild(`[CallMembership ${sender}:${this.deviceId}]`);\n this.matrixEventData = { eventId, sender };\n }\n\n /** @deprecated use userId instead */\n public get sender(): string {\n return this.userId;\n }\n\n public get userId(): string {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return data.member.user_id;\n case MembershipKind.Session:\n default:\n return this.matrixEventData.sender;\n }\n }\n\n public get eventId(): string {\n return this.matrixEventData.eventId;\n }\n\n /**\n * The ID of the MatrixRTC slot that this membership belongs to (format `{application}#{id}`).\n * This is computed in case SessionMembershipData is used.\n */\n public get slotId(): string {\n const { kind, data } = this.membershipData;\n if (data.application === \"m.call\") {\n switch (kind) {\n case MembershipKind.RTC:\n return data.slot_id;\n case MembershipKind.Session:\n default: {\n const [application, id] = [data.application, data.call_id];\n\n // INFO_SLOT_ID_LEGACY_CASE (search for all occurances of this INFO to get the full picture)\n // The spec got changed to use `\"ROOM\"` instead of `\"\"` empyt string for the implicit default call.\n // State events still are sent with `\"\"` however. To find other events that should end up in the same call,\n // we use the slotId.\n // Since the CallMembership is the public representation of a rtc.member event, we just pretend it is a\n // \"ROOM\" slotId/call_id.\n // This makes all the remote members work with just this simple trick.\n //\n // We of course now need to be careful when sending legacy events (state events)\n // They get a slotDescription containing \"ROOM\" since this is what we use starting at the time this comment\n // is commited.\n //\n // See the Other INFO_SLOT_ID_LEGACY_CASE comments to see where we revert back to \"\" just before sending the event.\n let compatibilityAdaptedId: string;\n if (id === \"\") {\n compatibilityAdaptedId = \"ROOM\";\n this.logger?.info(\"use slotId compat hack emptyString -> ROOM\");\n } else {\n compatibilityAdaptedId = id;\n }\n return computeSlotId({\n application,\n id: compatibilityAdaptedId,\n });\n }\n }\n }\n\n this.logger?.info(\"NOT using slotId compat hack emptyString -> ROOM\");\n // This is what the function should look like for any other application that did not\n // go through a `\"\"`=> `\"ROOM\"` rename\n switch (kind) {\n case MembershipKind.RTC:\n return data.slot_id;\n case MembershipKind.Session:\n default:\n return computeSlotId({ application: data.application, id: data.call_id });\n }\n }\n\n public get deviceId(): string {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return data.member.device_id;\n case MembershipKind.Session:\n default:\n return data.device_id;\n }\n }\n\n public get callIntent(): RTCCallIntent | undefined {\n const intent = this.applicationData[\"m.call.intent\"];\n if (typeof intent === \"string\") {\n return intent;\n }\n this.logger.warn(\"RTC membership has invalid m.call.intent\");\n return undefined;\n }\n\n /**\n * Parsed `slot_id` (format `{application}#{id}`) into its components (application and id).\n */\n public get slotDescription(): SlotDescription {\n const { kind, data } = this.membershipData;\n if (kind === MembershipKind.RTC) {\n const id = data.slot_id.slice(`${data.application.type}#`.length);\n return { application: data.application.type, id };\n }\n return slotIdToDescription(this.slotId);\n }\n\n /**\n * The application `type`.\n * @deprecated Use @see applicationData\n */\n public get application(): string {\n return this.applicationData.type;\n }\n\n /**\n * Information about the application being used for the RTC session.\n * May contain extra keys specific to the application.\n */\n public get applicationData(): { type: string; [key: string]: unknown } {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return data.application;\n case MembershipKind.Session:\n default:\n // SessionData does not have application data as such. We return specific\n // properties in use by other getters in this class, for compatibility.\n return { \"type\": data.application, \"m.call.intent\": data[\"m.call.intent\"] };\n }\n }\n\n /** @deprecated scope is not used and will be removed in future versions. replaced by application specific types.*/\n public get scope(): SessionMembershipData[\"scope\"] | undefined {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return undefined;\n case MembershipKind.Session:\n default:\n return data.scope;\n }\n }\n\n /**\n * This computes the membership ID for the membership.\n * For the sticky event based rtcSessionData this is trivial it is `member.id`.\n * This is not supposed to be used to identity on an rtc backend. This is just a nouance for\n * a generated (sha256) anonymised identity. Only send `rtcBackendIdentity` to any rtc backend service.\n *\n * For the legacy sessionMemberEvents it is a bit more complex. Here we sometimes do not have this data\n * in the event content and we expected the SFU and the client to use `${this.matrixEventData.sender}:${data.device_id}`.\n *\n * So if there is no membershipID we use the hard coded jwt id default (`${this.matrixEventData.sender}:${data.device_id}`)\n * value (used until version 0.16.0)\n *\n * It is also possible for a session event to set a custom membershipID. in that case this will be used.\n */\n public get memberId(): string {\n // the createdTs behaves equivalent to the membershipID.\n // we only need the field for the legacy member events where we needed to update them\n // synapse ignores sending state events if they have the same content.\n const { kind, data } = this.membershipData;\n switch (kind) {\n case \"rtc\":\n return data.member.id;\n case \"session\":\n return (\n // best case we have a client already publishing the right custom membershipId\n data.membershipID ??\n // alternativly we use the hard coded jwt id defuatl value (used until version 0.16.0)\n `${this.matrixEventData.sender}:${data.device_id}`\n );\n default:\n throw Error(\"Not possible to get memberID without knowing the membership event kind\");\n }\n }\n\n /**\n * @deprecated renamed to `memberId`\n */\n public get membershipID(): string {\n return this.memberId;\n }\n\n public createdTs(): number {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n // TODO we need to read the referenced (relation) event if available to get the real created_ts\n return this.matrixEvent.getTs();\n case MembershipKind.Session:\n default:\n return data.created_ts ?? this.matrixEvent.getTs();\n }\n }\n\n /**\n * Gets the absolute expiry timestamp of the membership.\n * @returns The absolute expiry time of the membership as a unix timestamp in milliseconds or undefined if not applicable\n */\n public getAbsoluteExpiry(): number | undefined {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return undefined;\n case MembershipKind.Session:\n default:\n // TODO: calculate this from the MatrixRTCSession join configuration directly\n return this.createdTs() + (data.expires ?? DEFAULT_EXPIRE_DURATION);\n }\n }\n\n /**\n * @returns The number of milliseconds until the membership expires or undefined if applicable\n * @deprecated Not used by RTC events.\n */\n public getMsUntilExpiry(): number | undefined {\n const { kind } = this.membershipData;\n if (kind === MembershipKind.Session) {\n const absExpiry = this.getAbsoluteExpiry();\n if (absExpiry) {\n // Assume that local clock is sufficiently in sync with other clocks in the distributed system.\n // We used to try and adjust for the local clock being skewed, but there are cases where this is not accurate.\n // The current implementation allows for the local clock to be -infinity to +MatrixRTCSession.MEMBERSHIP_EXPIRY_TIME/2\n return absExpiry - Date.now();\n }\n }\n return undefined;\n }\n\n /**\n * @returns true if the membership has expired, otherwise false\n */\n public isExpired(): boolean {\n const { kind } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return false;\n case MembershipKind.Session:\n default:\n return this.getMsUntilExpiry()! <= 0;\n }\n }\n\n /**\n * ## RTC Membership\n * Gets the primary transport to use for this RTC membership (m.rtc.member).\n * This will return the primary transport that is used by this call membership to publish their media.\n * Directly relates to the `rtc_transports` field.\n *\n * ## Legacy session membership\n * In case of a legacy session membership (m.call.member) this will return the selected transport where\n * media is published. How this selection happens depends on the `focus_active` field of the session membership.\n * If the `focus_selection` is `oldest_membership` this will return the transport of the oldest membership\n * in the room (based on the `created_ts` field of the session membership).\n * If the `focus_selection` is `multi_sfu` it will return the first transport of the `foci_preferred` list.\n * (`multi_sfu` is equivalent to how `m.rtc.member` `rtc_transports` work).\n * @param oldestMembership For backwards compatibility with session membership (legacy). Unused in case of RTC membership.\n * Always required to make the consumer not care if it deals with RTC or session memberships.\n * @returns The transport this membership uses to publish media or undefined if no transport is available.\n */\n public getTransport(oldestMembership: CallMembership): Transport | undefined {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return data.rtc_transports[0];\n case MembershipKind.Session:\n switch (data.focus_active.focus_selection) {\n case \"oldest_membership\":\n if (CallMembership.equal(this, oldestMembership)) return data.foci_preferred[0];\n if (oldestMembership !== undefined) return oldestMembership.getTransport(oldestMembership);\n break;\n case \"multi_sfu\":\n return data.foci_preferred[0];\n default:\n // `focus_selection` not understood.\n return undefined;\n }\n break;\n default:\n return undefined;\n }\n }\n\n /**\n * The value of the `rtc_transports` field for RTC memberships (m.rtc.member).\n * Or the value of the `foci_preferred` field for legacy session memberships (m.call.member).\n */\n public get transports(): Transport[] {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return data.rtc_transports;\n case MembershipKind.Session:\n default:\n return data.foci_preferred;\n }\n }\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"CallMembership.js","names":["deepCompare","logger","computeSlotId","slotIdToDescription","checkRtcMembershipData","computeRtcIdentityRaw","checkSessionsMembershipData","MatrixRTCMembershipParseError","EventType","DEFAULT_EXPIRE_DURATION","MembershipKind","CallMembership","membershipDataFromMatrixEvent","matrixEvent","sender","getSender","evType","getType","data","getContent","undefined","Error","RTCMembership","kind","RTC","GroupCallMemberPrefix","Session","concat","ex","debug","parseFromEvent","_this","_asyncToGenerator","membershipData","rtcBackendIdentity","member","user_id","device_id","id","equal","a","b","constructor","eventId","getId","getChild","deviceId","matrixEventData","userId","_this$membershipData","slotId","_this$logger2","_this$membershipData2","application","slot_id","_ref","call_id","compatibilityAdaptedId","_this$logger","info","_this$membershipData3","callIntent","intent","applicationData","warn","slotDescription","_this$membershipData4","slice","type","length","_this$membershipData5","scope","_this$membershipData6","memberId","_data$membershipID","_this$membershipData7","membershipID","createdTs","_data$created_ts","_this$membershipData8","getTs","created_ts","getAbsoluteExpiry","_data$expires","_this$membershipData9","expires","getMsUntilExpiry","absExpiry","Date","now","isExpired","getTransport","oldestMembership","_this$membershipData0","rtc_transports","focus_active","focus_selection","foci_preferred","transports","_this$membershipData1"],"sources":["../../src/matrixrtc/CallMembership.ts"],"sourcesContent":["/*\nCopyright 2023-2026 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { deepCompare } from \"../utils.ts\";\nimport { type RTCCallIntent, type Transport, type SlotDescription } from \"./types.ts\";\nimport { type MatrixEvent } from \"../models/event.ts\";\nimport { type Logger, logger } from \"../logger.ts\";\nimport { computeSlotId, slotIdToDescription } from \"./utils.ts\";\nimport {\n checkRtcMembershipData,\n computeRtcIdentityRaw,\n type RtcMembershipData,\n checkSessionsMembershipData,\n type SessionMembershipData,\n MatrixRTCMembershipParseError,\n} from \"./membershipData/index.ts\";\nimport { EventType } from \"../@types/event.ts\";\n\n/**\n * The default duration in milliseconds that a membership is considered valid for.\n * Ordinarily the client responsible for the session will update the membership before it expires.\n * We use this duration as the fallback case where stale sessions are present for some reason.\n */\nexport const DEFAULT_EXPIRE_DURATION = 1000 * 60 * 60 * 4;\n\n/**\n * Describes the source event type that provided the membership data.\n */\nenum MembershipKind {\n /**\n * The modern MSC4143 format event.\n */\n RTC = \"rtc\",\n /**\n * The legacy call event type.\n */\n Session = \"session\",\n}\n\ntype MembershipData =\n | { kind: MembershipKind.RTC; data: RtcMembershipData }\n | { kind: MembershipKind.Session; data: SessionMembershipData };\n\ntype LimitedEvent = Pick<MatrixEvent, \"getId\" | \"getSender\" | \"getTs\" | \"getType\" | \"getContent\">;\n// TODO: Rename to RtcMembership once we removed the legacy SessionMembership is removed, to avoid confusion.\nexport class CallMembership {\n /**\n * Parse the membershipdata from a call membership event.\n * @param matrixEvent The Matrix event to read.\n * @returns MembershipData in either MembershipKind.RTC or MembershipKind.Session format.\n * @throws If the content is neither format.\n */\n public static membershipDataFromMatrixEvent(matrixEvent: LimitedEvent): MembershipData {\n const sender = matrixEvent.getSender();\n const evType = matrixEvent.getType();\n const data = matrixEvent.getContent();\n if (sender === undefined) throw new Error(\"matrixEvent is missing sender field\");\n try {\n // Event types are strictly checked here.\n if (evType === EventType.RTCMembership && checkRtcMembershipData(data, sender)) {\n return { kind: MembershipKind.RTC, data };\n } else if (evType === EventType.GroupCallMemberPrefix && checkSessionsMembershipData(data)) {\n return { kind: MembershipKind.Session, data };\n } else {\n throw Error(`'${evType} is not a known call membership type`);\n }\n } catch (ex) {\n if (ex instanceof MatrixRTCMembershipParseError) {\n logger.debug(\"CallMembership.MatrixRTCMembershipParseError provided invalid data\", data);\n }\n throw ex;\n }\n }\n\n /**\n * Parse the contents of a MatrixEvent and create a CallMembership instance.\n * @param matrixEvent The Matrix event to read.\n */\n public static async parseFromEvent(matrixEvent: LimitedEvent): Promise<CallMembership> {\n const membershipData: MembershipData = this.membershipDataFromMatrixEvent(matrixEvent);\n const rtcBackendIdentity =\n membershipData.kind === MembershipKind.RTC\n ? await computeRtcIdentityRaw(\n membershipData.data.member.user_id,\n membershipData.data.member.device_id,\n membershipData.data.member.id,\n )\n : `${matrixEvent.getSender()}:${membershipData.data.device_id}`;\n return new CallMembership(matrixEvent, membershipData, rtcBackendIdentity);\n }\n\n public static equal(a?: CallMembership, b?: CallMembership): boolean {\n return deepCompare(a?.membershipData, b?.membershipData);\n }\n\n private logger: Logger;\n\n /** The parsed data from the Matrix event.\n * To access checked eventId and sender from the matrixEvent.\n * Class construction will fail if these values cannot get obtained. */\n private readonly matrixEventData: { eventId: string; sender: string };\n\n /**\n * Use `parseFromEvent`.\n * Constructor should only be used by tests.\n * @private\n * @param matrixEvent\n * @param membershipData\n * @param rtcBackendIdentity\n */\n public constructor(\n /** The Matrix event that this membership is based on */\n private readonly matrixEvent: LimitedEvent,\n private readonly membershipData: MembershipData,\n public readonly rtcBackendIdentity: string,\n ) {\n const eventId = matrixEvent.getId();\n const sender = matrixEvent.getSender();\n\n if (eventId === undefined) throw new Error(\"parentEvent is missing eventId field\");\n if (sender === undefined) throw new Error(\"parentEvent is missing sender field\");\n\n this.logger = logger.getChild(`[CallMembership ${sender}:${this.deviceId}]`);\n this.matrixEventData = { eventId, sender };\n }\n\n /** @deprecated use userId instead */\n public get sender(): string {\n return this.userId;\n }\n\n public get userId(): string {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return data.member.user_id;\n case MembershipKind.Session:\n default:\n return this.matrixEventData.sender;\n }\n }\n\n public get eventId(): string {\n return this.matrixEventData.eventId;\n }\n\n /**\n * The ID of the MatrixRTC slot that this membership belongs to (format `{application}#{id}`).\n * This is computed in case SessionMembershipData is used.\n */\n public get slotId(): string {\n const { kind, data } = this.membershipData;\n if (data.application === \"m.call\") {\n switch (kind) {\n case MembershipKind.RTC:\n return data.slot_id;\n case MembershipKind.Session:\n default: {\n const [application, id] = [data.application, data.call_id];\n\n // INFO_SLOT_ID_LEGACY_CASE (search for all occurances of this INFO to get the full picture)\n // The spec got changed to use `\"ROOM\"` instead of `\"\"` empyt string for the implicit default call.\n // State events still are sent with `\"\"` however. To find other events that should end up in the same call,\n // we use the slotId.\n // Since the CallMembership is the public representation of a rtc.member event, we just pretend it is a\n // \"ROOM\" slotId/call_id.\n // This makes all the remote members work with just this simple trick.\n //\n // We of course now need to be careful when sending legacy events (state events)\n // They get a slotDescription containing \"ROOM\" since this is what we use starting at the time this comment\n // is commited.\n //\n // See the Other INFO_SLOT_ID_LEGACY_CASE comments to see where we revert back to \"\" just before sending the event.\n let compatibilityAdaptedId: string;\n if (id === \"\") {\n compatibilityAdaptedId = \"ROOM\";\n this.logger?.info(\"use slotId compat hack emptyString -> ROOM\");\n } else {\n compatibilityAdaptedId = id;\n }\n return computeSlotId({\n application,\n id: compatibilityAdaptedId,\n });\n }\n }\n }\n\n this.logger?.info(\"NOT using slotId compat hack emptyString -> ROOM\");\n // This is what the function should look like for any other application that did not\n // go through a `\"\"`=> `\"ROOM\"` rename\n switch (kind) {\n case MembershipKind.RTC:\n return data.slot_id;\n case MembershipKind.Session:\n default:\n return computeSlotId({ application: data.application, id: data.call_id });\n }\n }\n\n public get deviceId(): string {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return data.member.device_id;\n case MembershipKind.Session:\n default:\n return data.device_id;\n }\n }\n\n public get callIntent(): RTCCallIntent | undefined {\n const intent = this.applicationData[\"m.call.intent\"];\n if (typeof intent === \"string\") {\n return intent;\n }\n this.logger.warn(\"RTC membership has invalid m.call.intent\");\n return undefined;\n }\n\n /**\n * Parsed `slot_id` (format `{application}#{id}`) into its components (application and id).\n */\n public get slotDescription(): SlotDescription {\n const { kind, data } = this.membershipData;\n if (kind === MembershipKind.RTC) {\n const id = data.slot_id.slice(`${data.application.type}#`.length);\n return { application: data.application.type, id };\n }\n return slotIdToDescription(this.slotId);\n }\n\n /**\n * The application `type`.\n * @deprecated Use @see applicationData\n */\n public get application(): string {\n return this.applicationData.type;\n }\n\n /**\n * Information about the application being used for the RTC session.\n * May contain extra keys specific to the application.\n */\n public get applicationData(): { type: string; [key: string]: unknown } {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return data.application;\n case MembershipKind.Session:\n default:\n // SessionData does not have application data as such. We return specific\n // properties in use by other getters in this class, for compatibility.\n return { \"type\": data.application, \"m.call.intent\": data[\"m.call.intent\"] };\n }\n }\n\n /** @deprecated scope is not used and will be removed in future versions. replaced by application specific types.*/\n public get scope(): SessionMembershipData[\"scope\"] | undefined {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return undefined;\n case MembershipKind.Session:\n default:\n return data.scope;\n }\n }\n\n /**\n * This computes the membership ID for the membership.\n * For the sticky event based rtcSessionData this is trivial it is `member.id`.\n * This is not supposed to be used to identity on an rtc backend. This is just a nouance for\n * a generated (sha256) anonymised identity. Only send `rtcBackendIdentity` to any rtc backend service.\n *\n * For the legacy sessionMemberEvents it is a bit more complex. Here we sometimes do not have this data\n * in the event content and we expected the SFU and the client to use `${this.matrixEventData.sender}:${data.device_id}`.\n *\n * So if there is no membershipID we use the hard coded jwt id default (`${this.matrixEventData.sender}:${data.device_id}`)\n * value (used until version 0.16.0)\n *\n * It is also possible for a session event to set a custom membershipID. in that case this will be used.\n */\n public get memberId(): string {\n // the createdTs behaves equivalent to the membershipID.\n // we only need the field for the legacy member events where we needed to update them\n // synapse ignores sending state events if they have the same content.\n const { kind, data } = this.membershipData;\n switch (kind) {\n case \"rtc\":\n return data.member.id;\n case \"session\":\n return (\n // best case we have a client already publishing the right custom membershipId\n data.membershipID ??\n // alternativly we use the hard coded jwt id defuatl value (used until version 0.16.0)\n `${this.matrixEventData.sender}:${data.device_id}`\n );\n default:\n throw Error(\"Not possible to get memberID without knowing the membership event kind\");\n }\n }\n\n /**\n * @deprecated renamed to `memberId`\n */\n public get membershipID(): string {\n return this.memberId;\n }\n\n public createdTs(): number {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n // TODO we need to read the referenced (relation) event if available to get the real created_ts\n return this.matrixEvent.getTs();\n case MembershipKind.Session:\n default:\n return data.created_ts ?? this.matrixEvent.getTs();\n }\n }\n\n /**\n * Gets the absolute expiry timestamp of the membership.\n * @returns The absolute expiry time of the membership as a unix timestamp in milliseconds or undefined if not applicable\n */\n public getAbsoluteExpiry(): number | undefined {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return undefined;\n case MembershipKind.Session:\n default:\n // TODO: calculate this from the MatrixRTCSession join configuration directly\n return this.createdTs() + (data.expires ?? DEFAULT_EXPIRE_DURATION);\n }\n }\n\n /**\n * @returns The number of milliseconds until the membership expires or undefined if applicable\n * @deprecated Not used by RTC events.\n */\n public getMsUntilExpiry(): number | undefined {\n const { kind } = this.membershipData;\n if (kind === MembershipKind.Session) {\n const absExpiry = this.getAbsoluteExpiry();\n if (absExpiry) {\n // Assume that local clock is sufficiently in sync with other clocks in the distributed system.\n // We used to try and adjust for the local clock being skewed, but there are cases where this is not accurate.\n // The current implementation allows for the local clock to be -infinity to +MatrixRTCSession.MEMBERSHIP_EXPIRY_TIME/2\n return absExpiry - Date.now();\n }\n }\n return undefined;\n }\n\n /**\n * @returns true if the membership has expired, otherwise false\n */\n public isExpired(): boolean {\n const { kind } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return false;\n case MembershipKind.Session:\n default:\n return this.getMsUntilExpiry()! <= 0;\n }\n }\n\n /**\n * ## RTC Membership\n * Gets the primary transport to use for this RTC membership (m.rtc.member).\n * This will return the primary transport that is used by this call membership to publish their media.\n * Directly relates to the `rtc_transports` field.\n *\n * ## Legacy session membership\n * In case of a legacy session membership (m.call.member) this will return the selected transport where\n * media is published. How this selection happens depends on the `focus_active` field of the session membership.\n * If the `focus_selection` is `oldest_membership` this will return the transport of the oldest membership\n * in the room (based on the `created_ts` field of the session membership).\n * If the `focus_selection` is `multi_sfu` it will return the first transport of the `foci_preferred` list.\n * (`multi_sfu` is equivalent to how `m.rtc.member` `rtc_transports` work).\n * @param oldestMembership For backwards compatibility with session membership (legacy). Unused in case of RTC membership.\n * Always required to make the consumer not care if it deals with RTC or session memberships.\n * @returns The transport this membership uses to publish media or undefined if no transport is available.\n */\n public getTransport(oldestMembership: CallMembership): Transport | undefined {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return data.rtc_transports[0];\n case MembershipKind.Session:\n switch (data.focus_active.focus_selection) {\n case \"oldest_membership\":\n if (CallMembership.equal(this, oldestMembership)) return data.foci_preferred[0];\n if (oldestMembership !== undefined) return oldestMembership.getTransport(oldestMembership);\n break;\n case \"multi_sfu\":\n return data.foci_preferred[0];\n default:\n // `focus_selection` not understood.\n return undefined;\n }\n break;\n default:\n return undefined;\n }\n }\n\n /**\n * The value of the `rtc_transports` field for RTC memberships (m.rtc.member).\n * Or the value of the `foci_preferred` field for legacy session memberships (m.call.member).\n */\n public get transports(): Transport[] {\n const { kind, data } = this.membershipData;\n switch (kind) {\n case MembershipKind.RTC:\n return data.rtc_transports;\n case MembershipKind.Session:\n default:\n return data.foci_preferred;\n }\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,3 +1,4 @@
1
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
1
2
  import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
2
3
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
4
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
@@ -164,26 +165,12 @@ export class MatrixRTCSession extends TypedEventEmitter {
164
165
  var _this;
165
166
  super();
166
167
  _this = this;
167
- this.client = client;
168
- this.roomSubset = roomSubset;
169
- this.slotDescription = slotDescription;
170
- this.calculateMembershipsOpts = calculateMembershipsOpts;
171
- _defineProperty(this, "membershipManager", void 0);
172
- _defineProperty(this, "encryptionManager", void 0);
173
- _defineProperty(this, "joinConfig", void 0);
174
- _defineProperty(this, "logger", void 0);
175
- _defineProperty(this, "pendingNotificationToSend", void 0);
176
168
  /**
177
169
  * This timeout is responsible to track any expiration. We need to know when we have to start
178
170
  * to ignore other call members. There is no callback for this. This timeout will always be configured to
179
171
  * emit when the next membership expires.
180
172
  */
181
- _defineProperty(this, "expiryTimeout", void 0);
182
173
  _defineProperty(this, "memberships", []);
183
- /**
184
- * Resolves when the session has calculated the initial membership of the session.
185
- */
186
- _defineProperty(this, "initialMembershipCalculated", void 0);
187
174
  /**
188
175
  * Does membership need to be recalculated? This is set to false upon
189
176
  * recalculation.
@@ -270,6 +257,10 @@ export class MatrixRTCSession extends TypedEventEmitter {
270
257
  void ((_this$encryptionManag = _this.encryptionManager) === null || _this$encryptionManag === void 0 ? void 0 : _this$encryptionManag.onMembershipsUpdate(oldMemberships));
271
258
  _this.setExpiryTimer();
272
259
  }));
260
+ this.client = client;
261
+ this.roomSubset = roomSubset;
262
+ this.slotDescription = slotDescription;
263
+ this.calculateMembershipsOpts = calculateMembershipsOpts;
273
264
  this.logger = rootLogger.getChild("[MatrixRTCSession ".concat(roomSubset.roomId, " ").concat(slotDescription.application, "#").concat(slotDescription.id, "]"));
274
265
  this.roomSubset.on(RoomStateEvent.Members, this.onRoomMemberUpdate);
275
266
  this.roomSubset.on(RoomStickyEventsEvent.Update, this.onStickyEventUpdate);
@@ -327,7 +318,10 @@ export class MatrixRTCSession extends TypedEventEmitter {
327
318
  this.membershipManager = joinConfig !== null && joinConfig !== void 0 && joinConfig.unstableSendStickyEvents ? new StickyEventMembershipManager(joinConfig, this.roomSubset, this.client, this.slotDescription, ownMembershipIdentity.memberId, this.logger) : new MembershipManager(joinConfig, this.roomSubset, this.client, this.slotDescription, this.logger);
328
319
  this.reEmitter.reEmit(this.membershipManager, [MembershipManagerEvent.ProbablyLeft, MembershipManagerEvent.StatusChanged, MembershipManagerEvent.DelayIdChanged]);
329
320
  // Create Encryption manager
330
- var [room, _client, statistics] = [this.roomSubset, this.client, this.statistics];
321
+ var _ref3 = [this.roomSubset, this.client, this.statistics],
322
+ room = _ref3[0],
323
+ _client = _ref3[1],
324
+ statistics = _ref3[2];
331
325
  var transport = new ToDeviceKeyTransport(ownMembershipIdentity, room.roomId, _client, statistics);
332
326
  this.encryptionManager = new RTCEncryptionManager(ownMembershipIdentity, () => this.memberships, transport, (keyBin, encryptionKeyIndex, membership, rtcBackendIdentity) => {
333
327
  this.emit(MatrixRTCSessionEvent.EncryptionKeyChanged, keyBin, encryptionKeyIndex, membership, rtcBackendIdentity);
@@ -354,7 +348,8 @@ export class MatrixRTCSession extends TypedEventEmitter {
354
348
  * @deprecated use the joinRTCSession method instead
355
349
  */
356
350
  joinRoomSession(fociPreferred, multiSfuFocus, joinConfig) {
357
- var [userId, deviceId] = [this.client.getUserId(), this.client.getDeviceId()];
351
+ var userId = this.client.getUserId(),
352
+ deviceId = this.client.getDeviceId();
358
353
  // TODO this wants to become a UUID
359
354
  var memberId = "".concat(userId, ":").concat(deviceId);
360
355
  this.joinRTCSession({
@@ -478,7 +473,7 @@ export class MatrixRTCSession extends TypedEventEmitter {
478
473
  sendCallNotify(parentEventId, notificationType, callIntent) {
479
474
  var _this5 = this;
480
475
  var sendNotificationEvent = /*#__PURE__*/function () {
481
- var _ref3 = _asyncToGenerator(function* () {
476
+ var _ref4 = _asyncToGenerator(function* () {
482
477
  var content = {
483
478
  "m.mentions": {
484
479
  user_ids: [],
@@ -502,15 +497,17 @@ export class MatrixRTCSession extends TypedEventEmitter {
502
497
  };
503
498
  });
504
499
  return function sendNotificationEvent() {
505
- return _ref3.apply(this, arguments);
500
+ return _ref4.apply(this, arguments);
506
501
  };
507
502
  }();
508
503
  void sendNotificationEvent().then(notification => {
509
504
  // Join event_id and origin event content
510
505
  var newResult = _objectSpread(_objectSpread({}, notification.response), notification.content);
511
506
  this.emit(MatrixRTCSessionEvent.DidSendCallNotification, newResult);
512
- }).catch(_ref4 => {
513
- var [errorLegacy, errorNew] = _ref4;
507
+ }).catch(_ref5 => {
508
+ var _ref6 = _slicedToArray(_ref5, 2),
509
+ errorLegacy = _ref6[0],
510
+ errorNew = _ref6[1];
514
511
  return this.logger.error("Failed to send call notification", errorLegacy, errorNew);
515
512
  });
516
513
  }
@@ -598,10 +595,8 @@ function isValidMembership(membership, room, slotDescription, logger) {
598
595
  * Collects the raw member events from room state and sticky store.
599
596
  */
600
597
  function collectMembersEvents(room, options, logger) {
601
- var {
602
- listenForStickyEvents,
603
- listenForMemberStateEvents
604
- } = options;
598
+ var listenForStickyEvents = options.listenForStickyEvents,
599
+ listenForMemberStateEvents = options.listenForMemberStateEvents;
605
600
  var callMemberEvents = [];
606
601
  if (listenForStickyEvents) {
607
602
  // prefill with sticky events