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
@@ -68,16 +68,13 @@ export class TimelineWindow {
68
68
  constructor(client, timelineSet) {
69
69
  var _timelineSet$room;
70
70
  var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
71
- this.client = client;
72
- this.timelineSet = timelineSet;
73
- _defineProperty(this, "windowLimit", void 0);
74
71
  // these will be TimelineIndex objects; they delineate the 'start' and
75
72
  // 'end' of the window.
76
73
  //
77
74
  // start.index is inclusive; end.index is exclusive.
78
- _defineProperty(this, "start", void 0);
79
- _defineProperty(this, "end", void 0);
80
75
  _defineProperty(this, "eventCount", 0);
76
+ this.client = client;
77
+ this.timelineSet = timelineSet;
81
78
  this.windowLimit = opts.windowLimit || 1000;
82
79
  (_timelineSet$room = timelineSet.room) === null || _timelineSet$room === void 0 || _timelineSet$room.on(RoomEvent.Timeline, this.onTimelineEvent.bind(this));
83
80
  }
@@ -404,7 +401,6 @@ export class TimelineIndex {
404
401
  constructor(timeline, index) {
405
402
  this.timeline = timeline;
406
403
  this.index = index;
407
- _defineProperty(this, "pendingPaginate", void 0);
408
404
  }
409
405
 
410
406
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"timeline-window.js","names":["EventTimeline","logger","RoomEvent","DEBUG","debuglog","log","bind","DEFAULT_PAGINATE_LOOP_LIMIT","TimelineWindow","constructor","client","timelineSet","_timelineSet$room","opts","arguments","length","undefined","_defineProperty","windowLimit","room","on","Timeline","onTimelineEvent","load","initialEventId","initialWindowSize","initFields","timeline","Error","eventIndex","events","getEvents","findIndex","e","getId","endIndex","Math","min","ceil","startIndex","max","start","TimelineIndex","getBaseIndex","end","eventCount","getTimelineForEvent","Promise","resolve","getEventTimeline","then","getLiveTimeline","getTimelineIndex","direction","BACKWARDS","_this$start","FORWARDS","_this$end","extend","size","tl","count","retreat","advance","excess","unpaginate","_event","_room","_atStart","removed","onEventRemoved","index","canPaginate","minIndex","maxIndex","hasNeighbouringTimeline","getNeighbouringTimeline","paginationToken","getPaginationToken","Boolean","paginate","_arguments","_this","_asyncToGenerator","makeRequest","requestLimit","pendingPaginate","token","prom","paginateEventTimeline","backwards","limit","finally","r","delta","startOfTimeline","concat","result","_this$end2","_this$end3","i","push","cappedDelta","neighbour"],"sources":["../src/timeline-window.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 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 { type Direction, EventTimeline } from \"./models/event-timeline.ts\";\nimport { logger } from \"./logger.ts\";\nimport { type MatrixClient } from \"./client.ts\";\nimport { type EventTimelineSet } from \"./models/event-timeline-set.ts\";\nimport { type MatrixEvent } from \"./models/event.ts\";\nimport { type Room, RoomEvent } from \"./models/room.ts\";\n\n/**\n * @internal\n */\nconst DEBUG = false;\n\n/**\n * @internal\n */\n/* istanbul ignore next */\nconst debuglog = DEBUG ? logger.log.bind(logger) : function (): void {};\n\n/**\n * the number of times we ask the server for more events before giving up\n * this is currently higher than it needs to be to workaround lack of a filter\n * for excluding thread responses from main timeline pagination which can cause\n * giving up incorrectly - https://github.com/matrix-org/matrix-spec-proposals/pull/3874\n *\n * @internal\n */\nconst DEFAULT_PAGINATE_LOOP_LIMIT = 10;\n\ninterface IOpts {\n /**\n * Maximum number of events to keep in the window. If more events are retrieved via pagination requests,\n * excess events will be dropped from the other end of the window.\n */\n windowLimit?: number;\n}\n\nexport class TimelineWindow {\n private readonly windowLimit: number;\n // these will be TimelineIndex objects; they delineate the 'start' and\n // 'end' of the window.\n //\n // start.index is inclusive; end.index is exclusive.\n private start?: TimelineIndex;\n private end?: TimelineIndex;\n private eventCount = 0;\n\n /**\n * Construct a TimelineWindow.\n *\n * <p>This abstracts the separate timelines in a Matrix {@link Room} into a single iterable thing.\n * It keeps track of the start and endpoints of the window, which can be advanced with the help\n * of pagination requests.\n *\n * <p>Before the window is useful, it must be initialised by calling {@link TimelineWindow#load}.\n *\n * <p>Note that the window will not automatically extend itself when new events\n * are received from /sync; you should arrange to call {@link TimelineWindow#paginate}\n * on {@link RoomEvent.Timeline} events.\n *\n * <p>Note that constructing an instance of this class for a room adds a\n * listener for RoomEvent.Timeline events which is never removed. In theory\n * this should not cause a leak since the EventEmitter uses weak mappings.\n *\n * @param client - MatrixClient to be used for context/pagination\n * requests.\n *\n * @param timelineSet - The timelineSet to track\n *\n * @param opts - Configuration options for this window\n */\n public constructor(\n private readonly client: MatrixClient,\n private readonly timelineSet: EventTimelineSet,\n opts: IOpts = {},\n ) {\n this.windowLimit = opts.windowLimit || 1000;\n timelineSet.room?.on(RoomEvent.Timeline, this.onTimelineEvent.bind(this));\n }\n\n /**\n * Initialise the window to point at a given event, or the live timeline\n *\n * @param initialEventId - If given, the window will contain the\n * given event\n * @param initialWindowSize - Size of the initial window\n */\n public load(initialEventId?: string, initialWindowSize = 20): Promise<void> {\n // given an EventTimeline, find the event we were looking for, and initialise our\n // fields so that the event in question is in the middle of the window.\n const initFields = (timeline: EventTimeline | null): void => {\n if (!timeline) {\n throw new Error(\"No timeline given to initFields\");\n }\n\n let eventIndex: number;\n\n const events = timeline.getEvents();\n\n if (!initialEventId) {\n // we were looking for the live timeline: initialise to the end\n eventIndex = events.length;\n } else {\n eventIndex = events.findIndex((e) => e.getId() === initialEventId);\n\n if (eventIndex < 0) {\n throw new Error(\"getEventTimeline result didn't include requested event\");\n }\n }\n\n const endIndex = Math.min(events.length, eventIndex + Math.ceil(initialWindowSize / 2));\n const startIndex = Math.max(0, endIndex - initialWindowSize);\n this.start = new TimelineIndex(timeline, startIndex - timeline.getBaseIndex());\n this.end = new TimelineIndex(timeline, endIndex - timeline.getBaseIndex());\n this.eventCount = endIndex - startIndex;\n };\n\n // We avoid delaying the resolution of the promise by a reactor tick if we already have the data we need,\n // which is important to keep room-switching feeling snappy.\n if (this.timelineSet.getTimelineForEvent(initialEventId)) {\n initFields(this.timelineSet.getTimelineForEvent(initialEventId));\n return Promise.resolve();\n } else if (initialEventId) {\n return this.client.getEventTimeline(this.timelineSet, initialEventId).then(initFields);\n } else {\n initFields(this.timelineSet.getLiveTimeline());\n return Promise.resolve();\n }\n }\n\n /**\n * Get the TimelineIndex of the window in the given direction.\n *\n * @param direction - EventTimeline.BACKWARDS to get the TimelineIndex\n * at the start of the window; EventTimeline.FORWARDS to get the TimelineIndex at\n * the end.\n *\n * @returns The requested timeline index if one exists, null\n * otherwise.\n */\n public getTimelineIndex(direction: Direction): TimelineIndex | null {\n if (direction == EventTimeline.BACKWARDS) {\n return this.start ?? null;\n } else if (direction == EventTimeline.FORWARDS) {\n return this.end ?? null;\n } else {\n throw new Error(\"Invalid direction '\" + direction + \"'\");\n }\n }\n\n /**\n * Try to extend the window using events that are already in the underlying\n * TimelineIndex.\n *\n * @param direction - EventTimeline.BACKWARDS to try extending it\n * backwards; EventTimeline.FORWARDS to try extending it forwards.\n * @param size - number of events to try to extend by.\n *\n * @returns true if the window was extended, false otherwise.\n */\n public extend(direction: Direction, size: number): boolean {\n const tl = this.getTimelineIndex(direction);\n\n if (!tl) {\n debuglog(\"TimelineWindow: no timeline yet\");\n return false;\n }\n\n const count = direction == EventTimeline.BACKWARDS ? tl.retreat(size) : tl.advance(size);\n\n if (count) {\n this.eventCount += count;\n debuglog(\"TimelineWindow: increased cap by \" + count + \" (now \" + this.eventCount + \")\");\n // remove some events from the other end, if necessary\n const excess = this.eventCount - this.windowLimit;\n if (excess > 0) {\n this.unpaginate(excess, direction != EventTimeline.BACKWARDS);\n }\n return true;\n }\n\n return false;\n }\n\n private onTimelineEvent(_event?: MatrixEvent, _room?: Room, _atStart?: boolean, removed?: boolean): void {\n if (removed) {\n this.onEventRemoved();\n }\n }\n\n /**\n * If an event was removed, meaning this window is longer than the timeline,\n * shorten the window.\n */\n private onEventRemoved(): void {\n const events = this.getEvents();\n if (events.length > 0 && events[events.length - 1] === undefined && this.end) {\n this.end.index--;\n }\n }\n\n /**\n * Check if this window can be extended\n *\n * <p>This returns true if we either have more events, or if we have a\n * pagination token which means we can paginate in that direction. It does not\n * necessarily mean that there are more events available in that direction at\n * this time.\n *\n * @param direction - EventTimeline.BACKWARDS to check if we can\n * paginate backwards; EventTimeline.FORWARDS to check if we can go forwards\n *\n * @returns true if we can paginate in the given direction\n */\n public canPaginate(direction: Direction): boolean {\n const tl = this.getTimelineIndex(direction);\n\n if (!tl) {\n debuglog(\"TimelineWindow: no timeline yet\");\n return false;\n }\n\n if (direction == EventTimeline.BACKWARDS) {\n if (tl.index > tl.minIndex()) {\n return true;\n }\n } else {\n if (tl.index < tl.maxIndex()) {\n return true;\n }\n }\n\n const hasNeighbouringTimeline = tl.timeline.getNeighbouringTimeline(direction);\n const paginationToken = tl.timeline.getPaginationToken(direction);\n return Boolean(hasNeighbouringTimeline) || Boolean(paginationToken);\n }\n\n /**\n * Attempt to extend the window\n *\n * @param direction - EventTimeline.BACKWARDS to extend the window\n * backwards (towards older events); EventTimeline.FORWARDS to go forwards.\n *\n * @param size - number of events to try to extend by. If fewer than this\n * number are immediately available, then we return immediately rather than\n * making an API call.\n *\n * @param makeRequest - whether we should make API calls to\n * fetch further events if we don't have any at all. (This has no effect if\n * the room already knows about additional events in the relevant direction,\n * even if there are fewer than 'size' of them, as we will just return those\n * we already know about.)\n *\n * @param requestLimit - limit for the number of API requests we\n * should make.\n *\n * @returns Promise which resolves to a boolean which is true if more events\n * were successfully retrieved.\n */\n public async paginate(\n direction: Direction,\n size: number,\n makeRequest = true,\n requestLimit = DEFAULT_PAGINATE_LOOP_LIMIT,\n ): Promise<boolean> {\n // Either wind back the message cap (if there are enough events in the\n // timeline to do so), or fire off a pagination request.\n const tl = this.getTimelineIndex(direction);\n\n if (!tl) {\n debuglog(\"TimelineWindow: no timeline yet\");\n return false;\n }\n\n if (tl.pendingPaginate) {\n return tl.pendingPaginate;\n }\n\n // try moving the cap\n if (this.extend(direction, size)) {\n return true;\n }\n\n if (!makeRequest || requestLimit === 0) {\n // todo: should we return something different to indicate that there\n // might be more events out there, but we haven't found them yet?\n return false;\n }\n\n // try making a pagination request\n const token = tl.timeline.getPaginationToken(direction);\n if (!token) {\n debuglog(\"TimelineWindow: no token\");\n return false;\n }\n\n debuglog(\"TimelineWindow: starting request\");\n\n const prom = this.client\n .paginateEventTimeline(tl.timeline, {\n backwards: direction == EventTimeline.BACKWARDS,\n limit: size,\n })\n .finally(function () {\n tl.pendingPaginate = undefined;\n })\n .then((r) => {\n debuglog(\"TimelineWindow: request completed with result \" + r);\n if (!r) {\n return this.paginate(direction, size, false, 0);\n }\n\n // recurse to advance the index into the results.\n //\n // If we don't get any new events, we want to make sure we keep asking\n // the server for events for as long as we have a valid pagination\n // token. In particular, we want to know if we've actually hit the\n // start of the timeline, or if we just happened to know about all of\n // the events thanks to https://matrix.org/jira/browse/SYN-645.\n //\n // On the other hand, we necessarily want to wait forever for the\n // server to make its mind up about whether there are other events,\n // because it gives a bad user experience\n // (https://github.com/vector-im/vector-web/issues/1204).\n return this.paginate(direction, size, true, requestLimit - 1);\n });\n tl.pendingPaginate = prom;\n return prom;\n }\n\n /**\n * Remove `delta` events from the start or end of the timeline.\n *\n * @param delta - number of events to remove from the timeline\n * @param startOfTimeline - if events should be removed from the start\n * of the timeline.\n */\n public unpaginate(delta: number, startOfTimeline: boolean): void {\n const tl = startOfTimeline ? this.start : this.end;\n if (!tl) {\n throw new Error(\n `Attempting to unpaginate startOfTimeline=${startOfTimeline} but don't have this direction`,\n );\n }\n\n // sanity-check the delta\n if (delta > this.eventCount || delta < 0) {\n throw new Error(\n `Attemting to unpaginate ${delta} events, but only have ${this.eventCount} in the timeline`,\n );\n }\n\n while (delta > 0) {\n const count = startOfTimeline ? tl.advance(delta) : tl.retreat(delta);\n if (count <= 0) {\n // sadness. This shouldn't be possible.\n throw new Error(\"Unable to unpaginate any further, but still have \" + this.eventCount + \" events\");\n }\n\n delta -= count;\n this.eventCount -= count;\n debuglog(\"TimelineWindow.unpaginate: dropped \" + count + \" (now \" + this.eventCount + \")\");\n }\n }\n\n /**\n * Get a list of the events currently in the window\n *\n * @returns the events in the window\n */\n public getEvents(): MatrixEvent[] {\n if (!this.start) {\n // not yet loaded\n return [];\n }\n\n const result: MatrixEvent[] = [];\n\n // iterate through each timeline between this.start and this.end\n // (inclusive).\n let timeline: EventTimeline | null = this.start.timeline;\n // eslint-disable-next-line no-constant-condition\n while (timeline) {\n const events = timeline.getEvents();\n\n // For the first timeline in the chain, we want to start at\n // this.start.index. For the last timeline in the chain, we want to\n // stop before this.end.index. Otherwise, we want to copy all of the\n // events in the timeline.\n //\n // (Note that both this.start.index and this.end.index are relative\n // to their respective timelines' BaseIndex).\n //\n let startIndex = 0;\n let endIndex = events.length;\n if (timeline === this.start.timeline) {\n startIndex = this.start.index + timeline.getBaseIndex();\n }\n if (timeline === this.end?.timeline) {\n endIndex = this.end.index + timeline.getBaseIndex();\n }\n\n for (let i = startIndex; i < endIndex; i++) {\n result.push(events[i]);\n }\n\n // if we're not done, iterate to the next timeline.\n if (timeline === this.end?.timeline) {\n break;\n } else {\n timeline = timeline.getNeighbouringTimeline(EventTimeline.FORWARDS);\n }\n }\n\n return result;\n }\n}\n\n/**\n * A thing which contains a timeline reference, and an index into it.\n * @internal\n */\nexport class TimelineIndex {\n public pendingPaginate?: Promise<boolean>;\n\n // index: the indexes are relative to BaseIndex, so could well be negative.\n public constructor(\n public timeline: EventTimeline,\n public index: number,\n ) {}\n\n /**\n * @returns the minimum possible value for the index in the current\n * timeline\n */\n public minIndex(): number {\n return this.timeline.getBaseIndex() * -1;\n }\n\n /**\n * @returns the maximum possible value for the index in the current\n * timeline (exclusive - ie, it actually returns one more than the index\n * of the last element).\n */\n public maxIndex(): number {\n return this.timeline.getEvents().length - this.timeline.getBaseIndex();\n }\n\n /**\n * Try move the index forward, or into the neighbouring timeline\n *\n * @param delta - number of events to advance by\n * @returns number of events successfully advanced by\n */\n public advance(delta: number): number {\n if (!delta) {\n return 0;\n }\n\n // first try moving the index in the current timeline. See if there is room\n // to do so.\n let cappedDelta;\n if (delta < 0) {\n // we want to wind the index backwards.\n //\n // (this.minIndex() - this.index) is a negative number whose magnitude\n // is the amount of room we have to wind back the index in the current\n // timeline. We cap delta to this quantity.\n cappedDelta = Math.max(delta, this.minIndex() - this.index);\n if (cappedDelta < 0) {\n this.index += cappedDelta;\n return cappedDelta;\n }\n } else {\n // we want to wind the index forwards.\n //\n // (this.maxIndex() - this.index) is a (positive) number whose magnitude\n // is the amount of room we have to wind forward the index in the current\n // timeline. We cap delta to this quantity.\n cappedDelta = Math.min(delta, this.maxIndex() - this.index);\n if (cappedDelta > 0) {\n this.index += cappedDelta;\n return cappedDelta;\n }\n }\n\n // the index is already at the start/end of the current timeline.\n //\n // next see if there is a neighbouring timeline to switch to.\n const neighbour = this.timeline.getNeighbouringTimeline(\n delta < 0 ? EventTimeline.BACKWARDS : EventTimeline.FORWARDS,\n );\n if (neighbour) {\n this.timeline = neighbour;\n if (delta < 0) {\n this.index = this.maxIndex();\n } else {\n this.index = this.minIndex();\n }\n\n debuglog(\"paginate: switched to new neighbour\");\n\n // recurse, using the next timeline\n return this.advance(delta);\n }\n\n return 0;\n }\n\n /**\n * Try move the index backwards, or into the neighbouring timeline\n *\n * @param delta - number of events to retreat by\n * @returns number of events successfully retreated by\n */\n public retreat(delta: number): number {\n return this.advance(delta * -1) * -1;\n }\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"timeline-window.js","names":["EventTimeline","logger","RoomEvent","DEBUG","debuglog","log","bind","DEFAULT_PAGINATE_LOOP_LIMIT","TimelineWindow","constructor","client","timelineSet","_timelineSet$room","opts","arguments","length","undefined","_defineProperty","windowLimit","room","on","Timeline","onTimelineEvent","load","initialEventId","initialWindowSize","initFields","timeline","Error","eventIndex","events","getEvents","findIndex","e","getId","endIndex","Math","min","ceil","startIndex","max","start","TimelineIndex","getBaseIndex","end","eventCount","getTimelineForEvent","Promise","resolve","getEventTimeline","then","getLiveTimeline","getTimelineIndex","direction","BACKWARDS","_this$start","FORWARDS","_this$end","extend","size","tl","count","retreat","advance","excess","unpaginate","_event","_room","_atStart","removed","onEventRemoved","index","canPaginate","minIndex","maxIndex","hasNeighbouringTimeline","getNeighbouringTimeline","paginationToken","getPaginationToken","Boolean","paginate","_arguments","_this","_asyncToGenerator","makeRequest","requestLimit","pendingPaginate","token","prom","paginateEventTimeline","backwards","limit","finally","r","delta","startOfTimeline","concat","result","_this$end2","_this$end3","i","push","cappedDelta","neighbour"],"sources":["../src/timeline-window.ts"],"sourcesContent":["/*\nCopyright 2016 - 2021 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 { type Direction, EventTimeline } from \"./models/event-timeline.ts\";\nimport { logger } from \"./logger.ts\";\nimport { type MatrixClient } from \"./client.ts\";\nimport { type EventTimelineSet } from \"./models/event-timeline-set.ts\";\nimport { type MatrixEvent } from \"./models/event.ts\";\nimport { type Room, RoomEvent } from \"./models/room.ts\";\n\n/**\n * @internal\n */\nconst DEBUG = false;\n\n/**\n * @internal\n */\n/* istanbul ignore next */\nconst debuglog = DEBUG ? logger.log.bind(logger) : function (): void {};\n\n/**\n * the number of times we ask the server for more events before giving up\n * this is currently higher than it needs to be to workaround lack of a filter\n * for excluding thread responses from main timeline pagination which can cause\n * giving up incorrectly - https://github.com/matrix-org/matrix-spec-proposals/pull/3874\n *\n * @internal\n */\nconst DEFAULT_PAGINATE_LOOP_LIMIT = 10;\n\ninterface IOpts {\n /**\n * Maximum number of events to keep in the window. If more events are retrieved via pagination requests,\n * excess events will be dropped from the other end of the window.\n */\n windowLimit?: number;\n}\n\nexport class TimelineWindow {\n private readonly windowLimit: number;\n // these will be TimelineIndex objects; they delineate the 'start' and\n // 'end' of the window.\n //\n // start.index is inclusive; end.index is exclusive.\n private start?: TimelineIndex;\n private end?: TimelineIndex;\n private eventCount = 0;\n\n /**\n * Construct a TimelineWindow.\n *\n * <p>This abstracts the separate timelines in a Matrix {@link Room} into a single iterable thing.\n * It keeps track of the start and endpoints of the window, which can be advanced with the help\n * of pagination requests.\n *\n * <p>Before the window is useful, it must be initialised by calling {@link TimelineWindow#load}.\n *\n * <p>Note that the window will not automatically extend itself when new events\n * are received from /sync; you should arrange to call {@link TimelineWindow#paginate}\n * on {@link RoomEvent.Timeline} events.\n *\n * <p>Note that constructing an instance of this class for a room adds a\n * listener for RoomEvent.Timeline events which is never removed. In theory\n * this should not cause a leak since the EventEmitter uses weak mappings.\n *\n * @param client - MatrixClient to be used for context/pagination\n * requests.\n *\n * @param timelineSet - The timelineSet to track\n *\n * @param opts - Configuration options for this window\n */\n public constructor(\n private readonly client: MatrixClient,\n private readonly timelineSet: EventTimelineSet,\n opts: IOpts = {},\n ) {\n this.windowLimit = opts.windowLimit || 1000;\n timelineSet.room?.on(RoomEvent.Timeline, this.onTimelineEvent.bind(this));\n }\n\n /**\n * Initialise the window to point at a given event, or the live timeline\n *\n * @param initialEventId - If given, the window will contain the\n * given event\n * @param initialWindowSize - Size of the initial window\n */\n public load(initialEventId?: string, initialWindowSize = 20): Promise<void> {\n // given an EventTimeline, find the event we were looking for, and initialise our\n // fields so that the event in question is in the middle of the window.\n const initFields = (timeline: EventTimeline | null): void => {\n if (!timeline) {\n throw new Error(\"No timeline given to initFields\");\n }\n\n let eventIndex: number;\n\n const events = timeline.getEvents();\n\n if (!initialEventId) {\n // we were looking for the live timeline: initialise to the end\n eventIndex = events.length;\n } else {\n eventIndex = events.findIndex((e) => e.getId() === initialEventId);\n\n if (eventIndex < 0) {\n throw new Error(\"getEventTimeline result didn't include requested event\");\n }\n }\n\n const endIndex = Math.min(events.length, eventIndex + Math.ceil(initialWindowSize / 2));\n const startIndex = Math.max(0, endIndex - initialWindowSize);\n this.start = new TimelineIndex(timeline, startIndex - timeline.getBaseIndex());\n this.end = new TimelineIndex(timeline, endIndex - timeline.getBaseIndex());\n this.eventCount = endIndex - startIndex;\n };\n\n // We avoid delaying the resolution of the promise by a reactor tick if we already have the data we need,\n // which is important to keep room-switching feeling snappy.\n if (this.timelineSet.getTimelineForEvent(initialEventId)) {\n initFields(this.timelineSet.getTimelineForEvent(initialEventId));\n return Promise.resolve();\n } else if (initialEventId) {\n return this.client.getEventTimeline(this.timelineSet, initialEventId).then(initFields);\n } else {\n initFields(this.timelineSet.getLiveTimeline());\n return Promise.resolve();\n }\n }\n\n /**\n * Get the TimelineIndex of the window in the given direction.\n *\n * @param direction - EventTimeline.BACKWARDS to get the TimelineIndex\n * at the start of the window; EventTimeline.FORWARDS to get the TimelineIndex at\n * the end.\n *\n * @returns The requested timeline index if one exists, null\n * otherwise.\n */\n public getTimelineIndex(direction: Direction): TimelineIndex | null {\n if (direction == EventTimeline.BACKWARDS) {\n return this.start ?? null;\n } else if (direction == EventTimeline.FORWARDS) {\n return this.end ?? null;\n } else {\n throw new Error(\"Invalid direction '\" + direction + \"'\");\n }\n }\n\n /**\n * Try to extend the window using events that are already in the underlying\n * TimelineIndex.\n *\n * @param direction - EventTimeline.BACKWARDS to try extending it\n * backwards; EventTimeline.FORWARDS to try extending it forwards.\n * @param size - number of events to try to extend by.\n *\n * @returns true if the window was extended, false otherwise.\n */\n public extend(direction: Direction, size: number): boolean {\n const tl = this.getTimelineIndex(direction);\n\n if (!tl) {\n debuglog(\"TimelineWindow: no timeline yet\");\n return false;\n }\n\n const count = direction == EventTimeline.BACKWARDS ? tl.retreat(size) : tl.advance(size);\n\n if (count) {\n this.eventCount += count;\n debuglog(\"TimelineWindow: increased cap by \" + count + \" (now \" + this.eventCount + \")\");\n // remove some events from the other end, if necessary\n const excess = this.eventCount - this.windowLimit;\n if (excess > 0) {\n this.unpaginate(excess, direction != EventTimeline.BACKWARDS);\n }\n return true;\n }\n\n return false;\n }\n\n private onTimelineEvent(_event?: MatrixEvent, _room?: Room, _atStart?: boolean, removed?: boolean): void {\n if (removed) {\n this.onEventRemoved();\n }\n }\n\n /**\n * If an event was removed, meaning this window is longer than the timeline,\n * shorten the window.\n */\n private onEventRemoved(): void {\n const events = this.getEvents();\n if (events.length > 0 && events[events.length - 1] === undefined && this.end) {\n this.end.index--;\n }\n }\n\n /**\n * Check if this window can be extended\n *\n * <p>This returns true if we either have more events, or if we have a\n * pagination token which means we can paginate in that direction. It does not\n * necessarily mean that there are more events available in that direction at\n * this time.\n *\n * @param direction - EventTimeline.BACKWARDS to check if we can\n * paginate backwards; EventTimeline.FORWARDS to check if we can go forwards\n *\n * @returns true if we can paginate in the given direction\n */\n public canPaginate(direction: Direction): boolean {\n const tl = this.getTimelineIndex(direction);\n\n if (!tl) {\n debuglog(\"TimelineWindow: no timeline yet\");\n return false;\n }\n\n if (direction == EventTimeline.BACKWARDS) {\n if (tl.index > tl.minIndex()) {\n return true;\n }\n } else {\n if (tl.index < tl.maxIndex()) {\n return true;\n }\n }\n\n const hasNeighbouringTimeline = tl.timeline.getNeighbouringTimeline(direction);\n const paginationToken = tl.timeline.getPaginationToken(direction);\n return Boolean(hasNeighbouringTimeline) || Boolean(paginationToken);\n }\n\n /**\n * Attempt to extend the window\n *\n * @param direction - EventTimeline.BACKWARDS to extend the window\n * backwards (towards older events); EventTimeline.FORWARDS to go forwards.\n *\n * @param size - number of events to try to extend by. If fewer than this\n * number are immediately available, then we return immediately rather than\n * making an API call.\n *\n * @param makeRequest - whether we should make API calls to\n * fetch further events if we don't have any at all. (This has no effect if\n * the room already knows about additional events in the relevant direction,\n * even if there are fewer than 'size' of them, as we will just return those\n * we already know about.)\n *\n * @param requestLimit - limit for the number of API requests we\n * should make.\n *\n * @returns Promise which resolves to a boolean which is true if more events\n * were successfully retrieved.\n */\n public async paginate(\n direction: Direction,\n size: number,\n makeRequest = true,\n requestLimit = DEFAULT_PAGINATE_LOOP_LIMIT,\n ): Promise<boolean> {\n // Either wind back the message cap (if there are enough events in the\n // timeline to do so), or fire off a pagination request.\n const tl = this.getTimelineIndex(direction);\n\n if (!tl) {\n debuglog(\"TimelineWindow: no timeline yet\");\n return false;\n }\n\n if (tl.pendingPaginate) {\n return tl.pendingPaginate;\n }\n\n // try moving the cap\n if (this.extend(direction, size)) {\n return true;\n }\n\n if (!makeRequest || requestLimit === 0) {\n // todo: should we return something different to indicate that there\n // might be more events out there, but we haven't found them yet?\n return false;\n }\n\n // try making a pagination request\n const token = tl.timeline.getPaginationToken(direction);\n if (!token) {\n debuglog(\"TimelineWindow: no token\");\n return false;\n }\n\n debuglog(\"TimelineWindow: starting request\");\n\n const prom = this.client\n .paginateEventTimeline(tl.timeline, {\n backwards: direction == EventTimeline.BACKWARDS,\n limit: size,\n })\n .finally(function () {\n tl.pendingPaginate = undefined;\n })\n .then((r) => {\n debuglog(\"TimelineWindow: request completed with result \" + r);\n if (!r) {\n return this.paginate(direction, size, false, 0);\n }\n\n // recurse to advance the index into the results.\n //\n // If we don't get any new events, we want to make sure we keep asking\n // the server for events for as long as we have a valid pagination\n // token. In particular, we want to know if we've actually hit the\n // start of the timeline, or if we just happened to know about all of\n // the events thanks to https://matrix.org/jira/browse/SYN-645.\n //\n // On the other hand, we necessarily want to wait forever for the\n // server to make its mind up about whether there are other events,\n // because it gives a bad user experience\n // (https://github.com/vector-im/vector-web/issues/1204).\n return this.paginate(direction, size, true, requestLimit - 1);\n });\n tl.pendingPaginate = prom;\n return prom;\n }\n\n /**\n * Remove `delta` events from the start or end of the timeline.\n *\n * @param delta - number of events to remove from the timeline\n * @param startOfTimeline - if events should be removed from the start\n * of the timeline.\n */\n public unpaginate(delta: number, startOfTimeline: boolean): void {\n const tl = startOfTimeline ? this.start : this.end;\n if (!tl) {\n throw new Error(\n `Attempting to unpaginate startOfTimeline=${startOfTimeline} but don't have this direction`,\n );\n }\n\n // sanity-check the delta\n if (delta > this.eventCount || delta < 0) {\n throw new Error(\n `Attemting to unpaginate ${delta} events, but only have ${this.eventCount} in the timeline`,\n );\n }\n\n while (delta > 0) {\n const count = startOfTimeline ? tl.advance(delta) : tl.retreat(delta);\n if (count <= 0) {\n // sadness. This shouldn't be possible.\n throw new Error(\"Unable to unpaginate any further, but still have \" + this.eventCount + \" events\");\n }\n\n delta -= count;\n this.eventCount -= count;\n debuglog(\"TimelineWindow.unpaginate: dropped \" + count + \" (now \" + this.eventCount + \")\");\n }\n }\n\n /**\n * Get a list of the events currently in the window\n *\n * @returns the events in the window\n */\n public getEvents(): MatrixEvent[] {\n if (!this.start) {\n // not yet loaded\n return [];\n }\n\n const result: MatrixEvent[] = [];\n\n // iterate through each timeline between this.start and this.end\n // (inclusive).\n let timeline: EventTimeline | null = this.start.timeline;\n // eslint-disable-next-line no-constant-condition\n while (timeline) {\n const events = timeline.getEvents();\n\n // For the first timeline in the chain, we want to start at\n // this.start.index. For the last timeline in the chain, we want to\n // stop before this.end.index. Otherwise, we want to copy all of the\n // events in the timeline.\n //\n // (Note that both this.start.index and this.end.index are relative\n // to their respective timelines' BaseIndex).\n //\n let startIndex = 0;\n let endIndex = events.length;\n if (timeline === this.start.timeline) {\n startIndex = this.start.index + timeline.getBaseIndex();\n }\n if (timeline === this.end?.timeline) {\n endIndex = this.end.index + timeline.getBaseIndex();\n }\n\n for (let i = startIndex; i < endIndex; i++) {\n result.push(events[i]);\n }\n\n // if we're not done, iterate to the next timeline.\n if (timeline === this.end?.timeline) {\n break;\n } else {\n timeline = timeline.getNeighbouringTimeline(EventTimeline.FORWARDS);\n }\n }\n\n return result;\n }\n}\n\n/**\n * A thing which contains a timeline reference, and an index into it.\n * @internal\n */\nexport class TimelineIndex {\n public pendingPaginate?: Promise<boolean>;\n\n // index: the indexes are relative to BaseIndex, so could well be negative.\n public constructor(\n public timeline: EventTimeline,\n public index: number,\n ) {}\n\n /**\n * @returns the minimum possible value for the index in the current\n * timeline\n */\n public minIndex(): number {\n return this.timeline.getBaseIndex() * -1;\n }\n\n /**\n * @returns the maximum possible value for the index in the current\n * timeline (exclusive - ie, it actually returns one more than the index\n * of the last element).\n */\n public maxIndex(): number {\n return this.timeline.getEvents().length - this.timeline.getBaseIndex();\n }\n\n /**\n * Try move the index forward, or into the neighbouring timeline\n *\n * @param delta - number of events to advance by\n * @returns number of events successfully advanced by\n */\n public advance(delta: number): number {\n if (!delta) {\n return 0;\n }\n\n // first try moving the index in the current timeline. See if there is room\n // to do so.\n let cappedDelta;\n if (delta < 0) {\n // we want to wind the index backwards.\n //\n // (this.minIndex() - this.index) is a negative number whose magnitude\n // is the amount of room we have to wind back the index in the current\n // timeline. We cap delta to this quantity.\n cappedDelta = Math.max(delta, this.minIndex() - this.index);\n if (cappedDelta < 0) {\n this.index += cappedDelta;\n return cappedDelta;\n }\n } else {\n // we want to wind the index forwards.\n //\n // (this.maxIndex() - this.index) is a (positive) number whose magnitude\n // is the amount of room we have to wind forward the index in the current\n // timeline. We cap delta to this quantity.\n cappedDelta = Math.min(delta, this.maxIndex() - this.index);\n if (cappedDelta > 0) {\n this.index += cappedDelta;\n return cappedDelta;\n }\n }\n\n // the index is already at the start/end of the current timeline.\n //\n // next see if there is a neighbouring timeline to switch to.\n const neighbour = this.timeline.getNeighbouringTimeline(\n delta < 0 ? EventTimeline.BACKWARDS : EventTimeline.FORWARDS,\n );\n if (neighbour) {\n this.timeline = neighbour;\n if (delta < 0) {\n this.index = this.maxIndex();\n } else {\n this.index = this.minIndex();\n }\n\n debuglog(\"paginate: switched to new neighbour\");\n\n // recurse, using the next timeline\n return this.advance(delta);\n }\n\n return 0;\n }\n\n /**\n * Try move the index backwards, or into the neighbouring timeline\n *\n * @param delta - number of events to retreat by\n * @returns number of events successfully retreated by\n */\n public retreat(delta: number): number {\n return this.advance(delta * -1) * -1;\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
  /*
3
4
  * Copyright 2024 The Matrix.org Foundation C.I.C.
@@ -31,7 +32,10 @@ export default function decryptAESSecretStorageItem(_x, _x2, _x3) {
31
32
  }
32
33
  function _decryptAESSecretStorageItem() {
33
34
  _decryptAESSecretStorageItem = _asyncToGenerator(function* (data, key, name) {
34
- var [aesKey, hmacKey] = yield deriveKeys(key, name);
35
+ var _yield$deriveKeys = yield deriveKeys(key, name),
36
+ _yield$deriveKeys2 = _slicedToArray(_yield$deriveKeys, 2),
37
+ aesKey = _yield$deriveKeys2[0],
38
+ hmacKey = _yield$deriveKeys2[1];
35
39
  var ciphertext = decodeBase64(data.ciphertext);
36
40
  if (!(yield globalThis.crypto.subtle.verify({
37
41
  name: "HMAC"
@@ -1 +1 @@
1
- {"version":3,"file":"decryptAESSecretStorageItem.js","names":["decodeBase64","deriveKeys","decryptAESSecretStorageItem","_x","_x2","_x3","_decryptAESSecretStorageItem","apply","arguments","_asyncToGenerator","data","key","name","aesKey","hmacKey","ciphertext","globalThis","crypto","subtle","verify","mac","Error","concat","plaintext","decrypt","counter","iv","length","TextDecoder","decode","Uint8Array"],"sources":["../../src/utils/decryptAESSecretStorageItem.ts"],"sourcesContent":["/*\n * Copyright 2024 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { decodeBase64 } from \"../base64.ts\";\nimport { deriveKeys } from \"./internal/deriveKeys.ts\";\nimport { type AESEncryptedSecretStoragePayload } from \"../@types/AESEncryptedSecretStoragePayload.ts\";\n\n/**\n * Decrypt an AES-encrypted Secret Storage item.\n *\n * @param data - the encrypted data, returned by {@link utils/encryptAESSecretStorageItem.default | encryptAESSecretStorageItem}.\n * @param key - the encryption key to use as an input to the HKDF function which is used to derive the AES key. Must\n * be the same as provided to {@link utils/encryptAESSecretStorageItem.default | encryptAESSecretStorageItem}.\n * @param name - the name of the secret. Also used as an input to the HKDF operation which is used to derive the AES\n * key, so again must be the same as provided to {@link utils/encryptAESSecretStorageItem.default | encryptAESSecretStorageItem}.\n */\nexport default async function decryptAESSecretStorageItem(\n data: AESEncryptedSecretStoragePayload,\n key: Uint8Array<ArrayBuffer>,\n name: string,\n): Promise<string> {\n const [aesKey, hmacKey] = await deriveKeys(key, name);\n\n const ciphertext = decodeBase64(data.ciphertext);\n\n if (!(await globalThis.crypto.subtle.verify({ name: \"HMAC\" }, hmacKey, decodeBase64(data.mac), ciphertext))) {\n throw new Error(`Error decrypting secret ${name}: bad MAC`);\n }\n\n const plaintext = await globalThis.crypto.subtle.decrypt(\n {\n name: \"AES-CTR\",\n counter: decodeBase64(data.iv),\n length: 64,\n },\n aesKey,\n ciphertext,\n );\n\n return new TextDecoder().decode(new Uint8Array(plaintext));\n}\n"],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,SAASA,YAAY,QAAQ,cAAc;AAC3C,SAASC,UAAU,QAAQ,0BAA0B;AAGrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAA8BC,2BAA2BA,CAAAC,EAAA,EAAAC,GAAA,EAAAC,GAAA;EAAA,OAAAC,4BAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA;AAwBxD,SAAAF,6BAAA;EAAAA,4BAAA,GAAAG,iBAAA,CAxBc,WACXC,IAAsC,EACtCC,GAA4B,EAC5BC,IAAY,EACG;IACf,IAAM,CAACC,MAAM,EAAEC,OAAO,CAAC,SAASb,UAAU,CAACU,GAAG,EAAEC,IAAI,CAAC;IAErD,IAAMG,UAAU,GAAGf,YAAY,CAACU,IAAI,CAACK,UAAU,CAAC;IAEhD,IAAI,QAAQC,UAAU,CAACC,MAAM,CAACC,MAAM,CAACC,MAAM,CAAC;MAAEP,IAAI,EAAE;IAAO,CAAC,EAAEE,OAAO,EAAEd,YAAY,CAACU,IAAI,CAACU,GAAG,CAAC,EAAEL,UAAU,CAAC,CAAC,EAAE;MACzG,MAAM,IAAIM,KAAK,4BAAAC,MAAA,CAA4BV,IAAI,cAAW,CAAC;IAC/D;IAEA,IAAMW,SAAS,SAASP,UAAU,CAACC,MAAM,CAACC,MAAM,CAACM,OAAO,CACpD;MACIZ,IAAI,EAAE,SAAS;MACfa,OAAO,EAAEzB,YAAY,CAACU,IAAI,CAACgB,EAAE,CAAC;MAC9BC,MAAM,EAAE;IACZ,CAAC,EACDd,MAAM,EACNE,UACJ,CAAC;IAED,OAAO,IAAIa,WAAW,CAAC,CAAC,CAACC,MAAM,CAAC,IAAIC,UAAU,CAACP,SAAS,CAAC,CAAC;EAC9D,CAAC;EAAA,OAAAjB,4BAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA","ignoreList":[]}
1
+ {"version":3,"file":"decryptAESSecretStorageItem.js","names":["decodeBase64","deriveKeys","decryptAESSecretStorageItem","_x","_x2","_x3","_decryptAESSecretStorageItem","apply","arguments","_asyncToGenerator","data","key","name","_yield$deriveKeys","_yield$deriveKeys2","_slicedToArray","aesKey","hmacKey","ciphertext","globalThis","crypto","subtle","verify","mac","Error","concat","plaintext","decrypt","counter","iv","length","TextDecoder","decode","Uint8Array"],"sources":["../../src/utils/decryptAESSecretStorageItem.ts"],"sourcesContent":["/*\n * Copyright 2024 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { decodeBase64 } from \"../base64.ts\";\nimport { deriveKeys } from \"./internal/deriveKeys.ts\";\nimport { type AESEncryptedSecretStoragePayload } from \"../@types/AESEncryptedSecretStoragePayload.ts\";\n\n/**\n * Decrypt an AES-encrypted Secret Storage item.\n *\n * @param data - the encrypted data, returned by {@link utils/encryptAESSecretStorageItem.default | encryptAESSecretStorageItem}.\n * @param key - the encryption key to use as an input to the HKDF function which is used to derive the AES key. Must\n * be the same as provided to {@link utils/encryptAESSecretStorageItem.default | encryptAESSecretStorageItem}.\n * @param name - the name of the secret. Also used as an input to the HKDF operation which is used to derive the AES\n * key, so again must be the same as provided to {@link utils/encryptAESSecretStorageItem.default | encryptAESSecretStorageItem}.\n */\nexport default async function decryptAESSecretStorageItem(\n data: AESEncryptedSecretStoragePayload,\n key: Uint8Array<ArrayBuffer>,\n name: string,\n): Promise<string> {\n const [aesKey, hmacKey] = await deriveKeys(key, name);\n\n const ciphertext = decodeBase64(data.ciphertext);\n\n if (!(await globalThis.crypto.subtle.verify({ name: \"HMAC\" }, hmacKey, decodeBase64(data.mac), ciphertext))) {\n throw new Error(`Error decrypting secret ${name}: bad MAC`);\n }\n\n const plaintext = await globalThis.crypto.subtle.decrypt(\n {\n name: \"AES-CTR\",\n counter: decodeBase64(data.iv),\n length: 64,\n },\n aesKey,\n ciphertext,\n );\n\n return new TextDecoder().decode(new Uint8Array(plaintext));\n}\n"],"mappings":";;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,SAASA,YAAY,QAAQ,cAAc;AAC3C,SAASC,UAAU,QAAQ,0BAA0B;AAGrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAA8BC,2BAA2BA,CAAAC,EAAA,EAAAC,GAAA,EAAAC,GAAA;EAAA,OAAAC,4BAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA;AAwBxD,SAAAF,6BAAA;EAAAA,4BAAA,GAAAG,iBAAA,CAxBc,WACXC,IAAsC,EACtCC,GAA4B,EAC5BC,IAAY,EACG;IACf,IAAAC,iBAAA,SAAgCZ,UAAU,CAACU,GAAG,EAAEC,IAAI,CAAC;MAAAE,kBAAA,GAAAC,cAAA,CAAAF,iBAAA;MAA9CG,MAAM,GAAAF,kBAAA;MAAEG,OAAO,GAAAH,kBAAA;IAEtB,IAAMI,UAAU,GAAGlB,YAAY,CAACU,IAAI,CAACQ,UAAU,CAAC;IAEhD,IAAI,QAAQC,UAAU,CAACC,MAAM,CAACC,MAAM,CAACC,MAAM,CAAC;MAAEV,IAAI,EAAE;IAAO,CAAC,EAAEK,OAAO,EAAEjB,YAAY,CAACU,IAAI,CAACa,GAAG,CAAC,EAAEL,UAAU,CAAC,CAAC,EAAE;MACzG,MAAM,IAAIM,KAAK,4BAAAC,MAAA,CAA4Bb,IAAI,cAAW,CAAC;IAC/D;IAEA,IAAMc,SAAS,SAASP,UAAU,CAACC,MAAM,CAACC,MAAM,CAACM,OAAO,CACpD;MACIf,IAAI,EAAE,SAAS;MACfgB,OAAO,EAAE5B,YAAY,CAACU,IAAI,CAACmB,EAAE,CAAC;MAC9BC,MAAM,EAAE;IACZ,CAAC,EACDd,MAAM,EACNE,UACJ,CAAC;IAED,OAAO,IAAIa,WAAW,CAAC,CAAC,CAACC,MAAM,CAAC,IAAIC,UAAU,CAACP,SAAS,CAAC,CAAC;EAC9D,CAAC;EAAA,OAAApB,4BAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA","ignoreList":[]}
@@ -1,3 +1,4 @@
1
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
1
2
  import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
2
3
  /*
3
4
  * Copyright 2024 The Matrix.org Foundation C.I.C.
@@ -47,7 +48,10 @@ function _encryptAESSecretStorageItem() {
47
48
  // of a single bit of iv is a price we have to pay.
48
49
  iv[8] &= 0x7f;
49
50
  }
50
- var [aesKey, hmacKey] = yield deriveKeys(key, name);
51
+ var _yield$deriveKeys = yield deriveKeys(key, name),
52
+ _yield$deriveKeys2 = _slicedToArray(_yield$deriveKeys, 2),
53
+ aesKey = _yield$deriveKeys2[0],
54
+ hmacKey = _yield$deriveKeys2[1];
51
55
  var encodedData = new TextEncoder().encode(data);
52
56
  var ciphertext = yield globalThis.crypto.subtle.encrypt({
53
57
  name: "AES-CTR",
@@ -1 +1 @@
1
- {"version":3,"file":"encryptAESSecretStorageItem.js","names":["decodeBase64","encodeBase64","deriveKeys","encryptAESSecretStorageItem","_x","_x2","_x3","_x4","_encryptAESSecretStorageItem","apply","arguments","_asyncToGenerator","data","key","name","ivStr","iv","Uint8Array","globalThis","crypto","getRandomValues","aesKey","hmacKey","encodedData","TextEncoder","encode","ciphertext","subtle","encrypt","counter","length","hmac","sign","mac"],"sources":["../../src/utils/encryptAESSecretStorageItem.ts"],"sourcesContent":["/*\n * Copyright 2024 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { decodeBase64, encodeBase64 } from \"../base64.ts\";\nimport { deriveKeys } from \"./internal/deriveKeys.ts\";\nimport { type AESEncryptedSecretStoragePayload } from \"../@types/AESEncryptedSecretStoragePayload.ts\";\n\n/**\n * Encrypt a string as a secret storage item, using AES-CTR.\n *\n * @param data - the plaintext to encrypt\n * @param key - the encryption key to use as an input to the HKDF function which is used to derive the AES key for\n * encryption. Obviously, the same key must be provided when decrypting.\n * @param name - the name of the secret. Used as an input to the HKDF operation which is used to derive the AES key,\n * so again the same value must be provided when decrypting.\n * @param ivStr - the base64-encoded initialization vector to use. If not supplied, a random one will be generated.\n *\n * @returns The encrypted result, including the ciphertext itself, the initialization vector (as supplied in `ivStr`,\n * or generated), and an HMAC on the ciphertext — all base64-encoded.\n */\nexport default async function encryptAESSecretStorageItem(\n data: string,\n key: Uint8Array<ArrayBuffer>,\n name: string,\n ivStr?: string,\n): Promise<AESEncryptedSecretStoragePayload> {\n let iv: Uint8Array<ArrayBuffer>;\n if (ivStr) {\n iv = decodeBase64(ivStr);\n } else {\n iv = new Uint8Array(16);\n globalThis.crypto.getRandomValues(iv);\n\n // clear bit 63 of the IV to stop us hitting the 64-bit counter boundary\n // (which would mean we wouldn't be able to decrypt on Android). The loss\n // of a single bit of iv is a price we have to pay.\n iv[8] &= 0x7f;\n }\n\n const [aesKey, hmacKey] = await deriveKeys(key, name);\n const encodedData = new TextEncoder().encode(data);\n\n const ciphertext = await globalThis.crypto.subtle.encrypt(\n {\n name: \"AES-CTR\",\n counter: iv,\n length: 64,\n },\n aesKey,\n encodedData,\n );\n\n const hmac = await globalThis.crypto.subtle.sign({ name: \"HMAC\" }, hmacKey, ciphertext);\n\n return {\n iv: encodeBase64(iv),\n ciphertext: encodeBase64(new Uint8Array(ciphertext)),\n mac: encodeBase64(new Uint8Array(hmac)),\n };\n}\n"],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,SAASA,YAAY,EAAEC,YAAY,QAAQ,cAAc;AACzD,SAASC,UAAU,QAAQ,0BAA0B;AAGrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAA8BC,2BAA2BA,CAAAC,EAAA,EAAAC,GAAA,EAAAC,GAAA,EAAAC,GAAA;EAAA,OAAAC,4BAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA;AAuCxD,SAAAF,6BAAA;EAAAA,4BAAA,GAAAG,iBAAA,CAvCc,WACXC,IAAY,EACZC,GAA4B,EAC5BC,IAAY,EACZC,KAAc,EAC2B;IACzC,IAAIC,EAA2B;IAC/B,IAAID,KAAK,EAAE;MACPC,EAAE,GAAGhB,YAAY,CAACe,KAAK,CAAC;IAC5B,CAAC,MAAM;MACHC,EAAE,GAAG,IAAIC,UAAU,CAAC,EAAE,CAAC;MACvBC,UAAU,CAACC,MAAM,CAACC,eAAe,CAACJ,EAAE,CAAC;;MAErC;MACA;MACA;MACAA,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI;IACjB;IAEA,IAAM,CAACK,MAAM,EAAEC,OAAO,CAAC,SAASpB,UAAU,CAACW,GAAG,EAAEC,IAAI,CAAC;IACrD,IAAMS,WAAW,GAAG,IAAIC,WAAW,CAAC,CAAC,CAACC,MAAM,CAACb,IAAI,CAAC;IAElD,IAAMc,UAAU,SAASR,UAAU,CAACC,MAAM,CAACQ,MAAM,CAACC,OAAO,CACrD;MACId,IAAI,EAAE,SAAS;MACfe,OAAO,EAAEb,EAAE;MACXc,MAAM,EAAE;IACZ,CAAC,EACDT,MAAM,EACNE,WACJ,CAAC;IAED,IAAMQ,IAAI,SAASb,UAAU,CAACC,MAAM,CAACQ,MAAM,CAACK,IAAI,CAAC;MAAElB,IAAI,EAAE;IAAO,CAAC,EAAEQ,OAAO,EAAEI,UAAU,CAAC;IAEvF,OAAO;MACHV,EAAE,EAAEf,YAAY,CAACe,EAAE,CAAC;MACpBU,UAAU,EAAEzB,YAAY,CAAC,IAAIgB,UAAU,CAACS,UAAU,CAAC,CAAC;MACpDO,GAAG,EAAEhC,YAAY,CAAC,IAAIgB,UAAU,CAACc,IAAI,CAAC;IAC1C,CAAC;EACL,CAAC;EAAA,OAAAvB,4BAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA","ignoreList":[]}
1
+ {"version":3,"file":"encryptAESSecretStorageItem.js","names":["decodeBase64","encodeBase64","deriveKeys","encryptAESSecretStorageItem","_x","_x2","_x3","_x4","_encryptAESSecretStorageItem","apply","arguments","_asyncToGenerator","data","key","name","ivStr","iv","Uint8Array","globalThis","crypto","getRandomValues","_yield$deriveKeys","_yield$deriveKeys2","_slicedToArray","aesKey","hmacKey","encodedData","TextEncoder","encode","ciphertext","subtle","encrypt","counter","length","hmac","sign","mac"],"sources":["../../src/utils/encryptAESSecretStorageItem.ts"],"sourcesContent":["/*\n * Copyright 2024 The Matrix.org Foundation C.I.C.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { decodeBase64, encodeBase64 } from \"../base64.ts\";\nimport { deriveKeys } from \"./internal/deriveKeys.ts\";\nimport { type AESEncryptedSecretStoragePayload } from \"../@types/AESEncryptedSecretStoragePayload.ts\";\n\n/**\n * Encrypt a string as a secret storage item, using AES-CTR.\n *\n * @param data - the plaintext to encrypt\n * @param key - the encryption key to use as an input to the HKDF function which is used to derive the AES key for\n * encryption. Obviously, the same key must be provided when decrypting.\n * @param name - the name of the secret. Used as an input to the HKDF operation which is used to derive the AES key,\n * so again the same value must be provided when decrypting.\n * @param ivStr - the base64-encoded initialization vector to use. If not supplied, a random one will be generated.\n *\n * @returns The encrypted result, including the ciphertext itself, the initialization vector (as supplied in `ivStr`,\n * or generated), and an HMAC on the ciphertext — all base64-encoded.\n */\nexport default async function encryptAESSecretStorageItem(\n data: string,\n key: Uint8Array<ArrayBuffer>,\n name: string,\n ivStr?: string,\n): Promise<AESEncryptedSecretStoragePayload> {\n let iv: Uint8Array<ArrayBuffer>;\n if (ivStr) {\n iv = decodeBase64(ivStr);\n } else {\n iv = new Uint8Array(16);\n globalThis.crypto.getRandomValues(iv);\n\n // clear bit 63 of the IV to stop us hitting the 64-bit counter boundary\n // (which would mean we wouldn't be able to decrypt on Android). The loss\n // of a single bit of iv is a price we have to pay.\n iv[8] &= 0x7f;\n }\n\n const [aesKey, hmacKey] = await deriveKeys(key, name);\n const encodedData = new TextEncoder().encode(data);\n\n const ciphertext = await globalThis.crypto.subtle.encrypt(\n {\n name: \"AES-CTR\",\n counter: iv,\n length: 64,\n },\n aesKey,\n encodedData,\n );\n\n const hmac = await globalThis.crypto.subtle.sign({ name: \"HMAC\" }, hmacKey, ciphertext);\n\n return {\n iv: encodeBase64(iv),\n ciphertext: encodeBase64(new Uint8Array(ciphertext)),\n mac: encodeBase64(new Uint8Array(hmac)),\n };\n}\n"],"mappings":";;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,SAASA,YAAY,EAAEC,YAAY,QAAQ,cAAc;AACzD,SAASC,UAAU,QAAQ,0BAA0B;AAGrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wBAA8BC,2BAA2BA,CAAAC,EAAA,EAAAC,GAAA,EAAAC,GAAA,EAAAC,GAAA;EAAA,OAAAC,4BAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA;AAuCxD,SAAAF,6BAAA;EAAAA,4BAAA,GAAAG,iBAAA,CAvCc,WACXC,IAAY,EACZC,GAA4B,EAC5BC,IAAY,EACZC,KAAc,EAC2B;IACzC,IAAIC,EAA2B;IAC/B,IAAID,KAAK,EAAE;MACPC,EAAE,GAAGhB,YAAY,CAACe,KAAK,CAAC;IAC5B,CAAC,MAAM;MACHC,EAAE,GAAG,IAAIC,UAAU,CAAC,EAAE,CAAC;MACvBC,UAAU,CAACC,MAAM,CAACC,eAAe,CAACJ,EAAE,CAAC;;MAErC;MACA;MACA;MACAA,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI;IACjB;IAEA,IAAAK,iBAAA,SAAgCnB,UAAU,CAACW,GAAG,EAAEC,IAAI,CAAC;MAAAQ,kBAAA,GAAAC,cAAA,CAAAF,iBAAA;MAA9CG,MAAM,GAAAF,kBAAA;MAAEG,OAAO,GAAAH,kBAAA;IACtB,IAAMI,WAAW,GAAG,IAAIC,WAAW,CAAC,CAAC,CAACC,MAAM,CAAChB,IAAI,CAAC;IAElD,IAAMiB,UAAU,SAASX,UAAU,CAACC,MAAM,CAACW,MAAM,CAACC,OAAO,CACrD;MACIjB,IAAI,EAAE,SAAS;MACfkB,OAAO,EAAEhB,EAAE;MACXiB,MAAM,EAAE;IACZ,CAAC,EACDT,MAAM,EACNE,WACJ,CAAC;IAED,IAAMQ,IAAI,SAAShB,UAAU,CAACC,MAAM,CAACW,MAAM,CAACK,IAAI,CAAC;MAAErB,IAAI,EAAE;IAAO,CAAC,EAAEW,OAAO,EAAEI,UAAU,CAAC;IAEvF,OAAO;MACHb,EAAE,EAAEf,YAAY,CAACe,EAAE,CAAC;MACpBa,UAAU,EAAE5B,YAAY,CAAC,IAAIgB,UAAU,CAACY,UAAU,CAAC,CAAC;MACpDO,GAAG,EAAEnC,YAAY,CAAC,IAAIgB,UAAU,CAACiB,IAAI,CAAC;IAC1C,CAAC;EACL,CAAC;EAAA,OAAA1B,4BAAA,CAAAC,KAAA,OAAAC,SAAA;AAAA","ignoreList":[]}
package/lib/utils.js CHANGED
@@ -1,5 +1,6 @@
1
1
  import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
2
2
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
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; }
4
5
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
5
6
  /*
@@ -59,19 +60,23 @@ export function internaliseString(str) {
59
60
  */
60
61
  export function encodeParams(params, urlSearchParams) {
61
62
  var searchParams = urlSearchParams !== null && urlSearchParams !== void 0 ? urlSearchParams : new URLSearchParams();
62
- var _loop = function _loop(key) {
63
- if (val !== undefined && val !== null) {
64
- if (Array.isArray(val)) {
65
- val.forEach(v => {
66
- searchParams.append(key, String(v));
67
- });
68
- } else {
69
- searchParams.append(key, String(val));
63
+ var _loop = function _loop() {
64
+ _ref2 = _slicedToArray(_ref3, 2);
65
+ var key = _ref2[0];
66
+ var val = _ref2[1];
67
+ if (val !== undefined && val !== null) {
68
+ if (Array.isArray(val)) {
69
+ val.forEach(v => {
70
+ searchParams.append(key, String(v));
71
+ });
72
+ } else {
73
+ searchParams.append(key, String(val));
74
+ }
70
75
  }
71
- }
72
- };
73
- for (var [key, val] of Object.entries(params)) {
74
- _loop(key);
76
+ },
77
+ _ref2;
78
+ for (var _ref3 of Object.entries(params)) {
79
+ _loop();
75
80
  }
76
81
  return searchParams;
77
82
  }
@@ -285,7 +290,10 @@ export function deepSortedObjectEntries(obj) {
285
290
  // Apparently these are object types...
286
291
  if (obj === null || obj === undefined || Array.isArray(obj)) return obj;
287
292
  var pairs = [];
288
- for (var [k, v] of Object.entries(obj)) {
293
+ for (var _ref6 of Object.entries(obj)) {
294
+ var _ref5 = _slicedToArray(_ref6, 2);
295
+ var k = _ref5[0];
296
+ var v = _ref5[1];
289
297
  pairs.push([k, deepSortedObjectEntries(v)]);
290
298
  }
291
299
 
@@ -477,10 +485,8 @@ export function simpleRetryOperation(promiseFn, shouldRetry) {
477
485
  return promiseFn(attempt);
478
486
  }, {
479
487
  retries: Infinity,
480
- shouldRetry: shouldRetry ? _ref => {
481
- var {
482
- error
483
- } = _ref;
488
+ shouldRetry: shouldRetry ? _ref7 => {
489
+ var error = _ref7.error;
484
490
  return shouldRetry(error);
485
491
  } : undefined,
486
492
  factor: 2,
@@ -668,7 +674,10 @@ export function lexicographicCompare(a, b) {
668
674
  */
669
675
  export function recursivelyAssign(target, source) {
670
676
  var ignoreNullish = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
671
- for (var [sourceKey, sourceValue] of Object.entries(source)) {
677
+ for (var _ref0 of Object.entries(source)) {
678
+ var _ref9 = _slicedToArray(_ref0, 2);
679
+ var sourceKey = _ref9[0];
680
+ var sourceValue = _ref9[1];
672
681
  if (target[sourceKey] instanceof Object && sourceValue) {
673
682
  recursivelyAssign(target[sourceKey], sourceValue);
674
683
  continue;
@@ -703,7 +712,10 @@ export function isSupportedReceiptType(receiptType) {
703
712
  export function mapsEqual(x, y) {
704
713
  var eq = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : (v1, v2) => v1 === v2;
705
714
  if (x.size !== y.size) return false;
706
- for (var [k, v1] of x) {
715
+ for (var _ref11 of x) {
716
+ var _ref10 = _slicedToArray(_ref11, 2);
717
+ var k = _ref10[0];
718
+ var v1 = _ref10[1];
707
719
  var v2 = y.get(k);
708
720
  if (v2 === undefined || !eq(v1, v2)) return false;
709
721
  }
@@ -727,7 +739,10 @@ function processMapToObjectValue(value) {
727
739
  */
728
740
  export function recursiveMapToObject(map) {
729
741
  var targetMap = new Map();
730
- for (var [key, value] of map) {
742
+ for (var _ref14 of map) {
743
+ var _ref13 = _slicedToArray(_ref14, 2);
744
+ var key = _ref13[0];
745
+ var value = _ref13[1];
731
746
  targetMap.set(key, processMapToObjectValue(value));
732
747
  }
733
748
  return Object.fromEntries(targetMap.entries());