Changes in 5.1.1 (2020-03-17)
- Fix: ensureOlmSessionsForDevices parameter format #1265
- Fix: prevent error being thrown during sync in some cases #1262
- Force
is_verified
for key backups to bool and fix computation #1260
Changes in 5.1.1-rc.1 (2020-03-11)
- refactor megolm encryption to improve perceived speed #1252
- Remove v1 identity server fallbacks #1253
- Use alt_aliases instead of local ones for room names #1251
- Upload cross-signing key signatures in the background #1250
- Fix secret sharing names to match spec #1249
- Cleanup: remove crypto.verification.start event #1248
- Fix regression in key backup request params #1246
- Use cross-signing trust to mark backups verified #1244
- Check both cross-signing and local trust for key sharing #1243
- Fixed up tests to match new way that crypto stores are created #1242
- Store USK and SSK locally #1235
- Use unpadded base64 for QR code secrets #1236
- Don't require .done event for finishing self-verification #1239
- Don't cancel as 3rd party in verification request #1237
- Verification: log when switching start event #1234
- Perform crypto store operations directly after transaction #1233
- More verification request logging #1232
- Upgrade deps #1231
Changes in 5.1.0 (2020-03-02)
- No changes since rc.1
Changes in 5.1.0-rc.1 (2020-02-26)
- Add latest dist-tag for releases #1230
- Add room method for alt_aliases #1225
- Remove buildkite pipeline #1227
- don't assume verify has been called when receiving a cancellation in verifier #1226
- Reduce secret size for new binary packing #1221
- misc rageshake fixes #1223
- Fix cancelled historical requests not appearing as cancelled #1220
- Fix renaming error that broke QR code verification #1217
Changes in 5.0.1 (2020-02-19)
- add method for new /aliases endpoint #1219
- method for checking if other party supports verification method #1213
- add local echo state for accepting or declining a verif req #1210
- make logging compatible with rageshakes #1214
- Find existing requests when starting a new verification request #1209
- log MAC calculation during SAS #1211
Changes in 5.0.0 (2020-02-17)
- No changes since rc.1
Changes in 5.0.0-rc.1 (2020-02-13)
- The verification methods API has removed an argument (#1206)
- Remove methods argument to verification #1206
- don't do a dynamic import of request #1207
- QR self-verification fixes #1201
- Log every verification event #1204
- dont require .done event from other party #1203
- New option to fully reset Secret Storage keys in boostrapSecretStorage #1202
- Add function to estimate target device for a VerificationRequest #1190
- pass ssss item name to callback so we can differentiate UI on it #1200
- add export/import of Olm devices #1167
- Convert utils.js -> utils.ts #1199
- Don't sign ourselves as a user #1197
- Add a bunch of logging to verification #1196
- Fix: always return a valid string from InRoomChannel.getEventType #1198
- add logging when a request is being cancelled #1195
- Don't explode verification validation if we don't have an event type #1194
- Fix: verification request appearing for users that are not the receiver or sender if they are in room #1193
- Fix getting secrets encoded with passthrough keys #1192
- Update QR code handling for new spec #1175
- Don't add ephemeral events to timeline when peeking #1188
- Fix typo #1189
- Verification: resolve race between .start events from both parties #1187
- Add option to bootstrap to start new key backup #1184
- Add a bunch of null guards to feature checks #1182
- docs: fix MatrixClient reference #1183
- Add helper to obtain the cancellation code for a verification request #1180
- Publish pre-releases as a separate tag on npm #1178
- Fix support for passthrough keys #1177
- Trust our own cross-signing keys if we verify them with another device #1174
- Ensure cross-signing keys are downloaded when checking trust #1176
- Don't log verification validation errors for normal messages #1172
- Fix bootstrap cleanup #1173
- QR code verification #1155
- expose deviceId prop on device channel #1171
- Move & upgrade babel runtime into dependencies (like it wants) #1169
- Add unit tests for verifying your own device, remove .event property on verification request #1166
- For dm-verification, also consider events sent by other devices of same user as "our" events #1163
- Add a prepare script #1161
- Remove :deviceId from /keys/upload/:deviceId as not spec-compliant #1162
- Refactor and expose some logic publicly for the TimelineWindow class. #1159
- Allow a device key upload request without auth #1158
- Support for .ready verification event (MSC2366) & other things #1140
Changes in 4.0.0 (2020-01-27)
Changes in 4.0.0-rc.1 (2020-01-20)
- The js-sdk node module now exports ES6 rather than ES5. If you wish to supports target that aren't compatible with ES6, you will need to transpile the js-sdk to a suitable dialect.
- Convert secret storage to new account data API #1154
- Add v5 as a safe room version #1157
- Add API to get account data from server #1153
- Fix sourcemaps by refactoring the build system #1151
- record, report, and notify about olm errors #1146
- Send device messages for the same user in same API call. #1148
- Add an option to ignore unverified devices #1150
- Sign key backup with cross-signing key on upgrade #1144
- Emoji verification: Change name of 🔒 to lock #1145
- use a separate object for each encrypted content #1147
- Sourcemaps: develop -> feature branch #1143
- Use a safer import/export scheme for the ContentRepo utilities #1134
- Fix error handling in decryptGroupMessage #1142
- Add additional properties to package.json for riot-web's webpack #1131
- Fix import for indexeddb crypto store #1133
- Use the right request when creating clients #1132
- Target NodeJS 10, minified browser bundle, and other publishing/package things #1127
- Re-focus sourcemap generation #1126
- Remove ancient polyfill for prototype inheritance #1125
- Remove "source-map-support" from tests because it makes sourcemaps worse #1124
- Remove ancient "use strict" annotations #1123
- Use ES6 imports/exports instead of older CommonJS ones #1122
- [BREAKING] Refactor the entire build process #1113
Changes in 3.0.0 (2020-01-13)
- No changes from rc.1
Changes in 3.0.0-rc.1 (2020-01-06)
- matrix-js-sdk no longer uses bluebird promises, so promises returned by the js-sdk no longer support the done() method. Code that calls done() on promises returned by the js-sdk will break and will need to be updated to remove the done() call.
- Make displayName disambiguation more fuzzy especially against RTL/LTR content #1141
- stop trying to resend event if we get M_TOO_LARGE #1129
- Fix creating a key backup with cross signing diabled #1139
- Use checkDeviceTrust with key backup #1138
- Add support for passthrough SSSS secrets #1128
- Add support for key backups using secret storage #1118
- Remove unused user verification event #1117
- Fix check for private keys #1116
- Restore watching mode for
start:watch
#1115 - Add secret storage bootstrap flow #1079
- Part 1 of many: Upgrade to babel@7 and TypeScript #1112
- Remove Bluebird: phase 2.5 #1100
- Remove Bluebird: phase 3 #1088
- ignore m.key.verification.done messages when we don't expect any more messages #1104
- dont cancel on remote echo of own .request event #1111
- Refactor verification request code #1109
- Fix device list's cross-signing storage path #1105
- yarn upgrade #1103
Changes in 2.4.6 (2019-12-09)
- No changes since rc.1
Changes in 2.4.6-rc.1 (2019-12-04)
- Update alias handling #1102
- increase timeout on flush to fix failing unit test #1096
- Disable broken cross-signing test #1095
- Fix a couple SAS tests #1094
- Fix Olm unwedging test #1093
- Fix empty string handling in push notifications #1089
- expand e2ee logging to better debug UISIs #1090
- Remove Bluebird: phase 2 #1087
- Relax identity server discovery checks to FAIL_PROMPT #1062
- Fix incorrect return value of MatrixClient.prototype.uploadKeys #1061
- Fix calls in e2e rooms #1086
- Monitor verification request over DM as well #1085
- Remove 'check' npm script #1084
- Always process call events in batches #1083
- Fix ringing chirp on loading #1082
- Remove most bluebird specific things #1081
- Switch to Jest #1080
Changes in 2.4.5 (2019-11-27)
- Relax identity server discovery checks to FAIL_PROMPT
- Expand E2EE debug logging to diagnose "unable to decrypt" errors
Changes in 2.4.4 (2019-11-25)
- No changes since rc.1
Changes in 2.4.4-rc.1 (2019-11-20)
- Fix SAS verification in encrypted DMs #1077
- Cross-signing / secret storage tweaks #1078
- Fix local trust for key backups #1075
- Add method to get last active timestamp in room #1072
- Check the right Synapse endpoint for determining admin capabilities #1071
- Cross Signing Support #832
- Don't double cancel verification request #1064
- Support for verification requests in the timeline #1067
- Use stable API prefix for 3PID APIs when supported #1066
- Remove Jenkins scripts #1063
Changes in 2.4.3 (2019-11-04)
- No changes since rc.1
Changes in 2.4.3-rc.1 (2019-10-30)
- fix the path in references to logger.js #1056
- verification in DMs #1050
- Properly documented the function possible returns #1054
- Downgrade to Bluebird 3.5.5 to fix Firefox #1055
- Upgrade safe deps to latest major version #1053
- Don't include .js in the import string. #1052
Changes in 2.4.2 (2019-10-18)
- No changes since v2.4.2-rc.1
Changes in 2.4.2-rc.1 (2019-10-09)
Changes in 2.4.1 (2019-10-01)
Changes in 2.4.0 (2019-09-27)
- Clean Yarn cache during release #1045
Changes in 2.4.0-rc.1 (2019-09-25)
- Remove id_server from creds for interactive auth #1044
- Remove IS details from requestToken to HS #1041
- Add support for sending MSISDN tokens to alternate URLs #1040
- Add separate 3PID add and bind APIs #1038
- Bump eslint-utils from 1.4.0 to 1.4.2 #1037
- Handle WebRTC security errors as non-fatal #1036
- Check for r0.6.0 support in addition to unstable feature flags #1035
- Update room members on member event redaction #1030
- Support hidden read receipts #1028
- Do 3pid lookups in lowercase #1029
- Add Synapse admin functions for deactivating a user #1027
- Fix addPendingEvent with pending event order == chronological #1026
- Add AutoDiscovery.getRawClientConfig() for easy .well-known lookups #1024
- Don't convert errors to JSON if they are JSON already #1025
- Send id_access_token to HS for use in proxied IS requests #1022
- Clean up JSON handling in identity server requests #1023
- Use the v2 (hashed) lookup for identity server queries #1021
- Add getIdServer() & doesServerRequireIdServerParam() #1018
- Make requestToken endpoints work without ID Server #1019
- Fix setIdentityServer #1016
- Change ICE fallback server and make fallback opt-in #1015
- Throw an exception if trying to do an ID server request with no ID server #1014
- Add setIdentityServerUrl #1013
- Add matrix base API to report an event #1011
- Fix POST body for v2 IS requests #1010
- Add API for bulk lookup on the Identity Server #1009
- Remove deprecated authedRequestWithPrefix and requestWithPrefix #1000
- Add API for checking IS account info #1007
- Support rewriting push rules when our internal defaults change #1006
- Upgrade dependencies #1005
Changes in 2.3.2 (2019-09-16)
- [Release] Fix addPendingEvent with pending event order == chronological #1034
Changes in 2.3.2-rc.1 (2019-09-13)
Changes in 2.3.1 (2019-09-12)
- No changes since rc.1
Changes in 2.3.1-rc.1 (2019-09-11)
- Update room members on member event redaction #1031
Changes in 2.3.0 (2019-08-05)
- [release] Support rewriting push rules when our internal defaults change #1008
Changes in 2.3.0-rc.1 (2019-07-31)
- Add support for IS v2 API with authentication #1002
- Tombstone bugfixes #1001
- Support for MSC2140 (terms of service for IS/IM) #988
- Add a request method to /devices #994
Changes in 2.2.0 (2019-07-18)
- Upgrade lodash dependencies
Changes in 2.2.0-rc.2 (2019-07-12)
- Fix regression from 2.2.0-rc.1 in request to /devices #995
Changes in 2.2.0-rc.1 (2019-07-12)
- End the verification timer when verification is done #993
- Stabilize usage of stably stable APIs (in a stable way) #990
- Expose original_event for /relations #987
- Process ephemeral events outside timeline handling #989
- Don't accept any locally known edits earlier than the last known server-side aggregated edit #986
- Get edit date transparently from server aggregations or local echo #984
- Add a function to flag keys for backup without scheduling a backup #982
- Block read marker and read receipt from advancing into pending events #981
- Upgrade dependencies #977
- Add default push rule to ignore reactions #976
- Fix exception whilst syncing #979
- Include the error object when raising Session.logged_out #975
Changes in 2.1.1 (2019-07-11)
- Process emphemeral events outside timeline handling #989
Changes in 2.1.0 (2019-07-08)
- Fix exception whilst syncing #979
Changes in 2.1.0-rc.1 (2019-07-03)
- Handle self read receipts for fixing e2e notification counts #974
- Add redacts field to event.toJSON #973
- Handle associated event send failures #972
- Remove irrelevant debug line from timeline handling #971
- Handle relations in encrypted rooms #969
- Relations endpoint support #967
- Disable event encryption for reactions #968
- Change the known safe room version to version 4 #966
- Check for lazy-loading support in the spec versions instead #965
- Use camelCase instead of underscore #963
- Time out verification attempts after 10 minutes of inactivity #961
- Don't handle key verification requests which are immediately cancelled #962
Changes in 2.0.1 (2019-06-19)
No changes since rc.2
Changes in 2.0.1-rc.2 (2019-06-18)
- return 'sending' status for an event that is only locally redacted #960
- Key verification request fixes #954
- Add flag to force saving sync store #956
- Expose the inhibit_login flag to register #953
- Support redactions and relations of/with unsent events. #947
Changes in 2.0.1-rc.1 (2019-06-12)
- Fix content uploads for modern browsers #952
- Don't overlap auth submissions with polls #951
- Add funding details for GitHub sponsor button #945
- Fix backup sig validation with multiple sigs #944
- Don't send another token request while one's in flight #943
- Don't poll UI auth again until current poll finishes #942
- Provide the discovered URLs when a liveliness error occurs #938
- Encode event IDs when redacting events #941
- add missing logger #940
- verification: don't error if we don't know about some keys #939
- Local echo for redactions #937
- Refresh safe room versions when the server looks more modern than us #934
- Add v4 as a safe room version #935
- Disable guard-for-in rule #933
- Extend loglevel logging for the whole project #924
- fix(login): saves access_token and user_id after login for all login types #930
- Do not try to request thumbnails with non-integer sizes #929
- Revert "Add a bunch of debugging to .well-known IS validation" #928
- Add a bunch of debugging to .well-known IS validation #927
Changes in 2.0.0 (2019-05-31)
- This package now publishes in ES6 / ES2015 syntax to NPM
- Saves access_token and user_id after login for all login types #932
- Fix recovery key encoding for base-x 3.0.5 #931
Changes in 1.2.0 (2019-05-29)
Changes in 1.2.0-rc.1 (2019-05-23)
- interactive-auth now handles requesting email tokens #926
- allow access to unreplaced message content #923
- Add method to retrieve replacing event #922
- More logging when signature verification fails #921
- Local echo for m.replace relations #920
- Track relations as pending and remove when cancelled #919
- Add stringify helper to summarise events when debugging #916
- Message editing: filter out replacements for senders that are not the original sender #918
- Wait until decrypt before aggregating #917
- Message editing: mark original event as replaced instead of replacing the event object #914
- Support for replacing message through m.replace relationship. #913
- Use a short timeout for .well-known requests #912
- Redaction and change events for relations #911
- Add basic read path for relations #910
- Add a concept of default push rules, using it for tombstone notifications #860
- yarn upgrade #907
Changes in 1.1.0 (2019-05-07)
- No Changes since rc.1
Changes in 1.1.0-rc.1 (2019-04-30)
- use the release version of olm 3.1.0 #903
- Use new Olm repo link in README #901
- Support being fed a .well-known config object for validation #897
- emit self-membership event at end of handling sync update #900
- Use packages.matrix.org for Olm #898
- Fix tests on develop #899
- Stop syncing when the token is invalid #895
- change event redact, POST request to PUT request #887
- Expose better autodiscovery error messages #894
- Explicitly guard store usage during sync startup #892
- Flag v3 rooms as safe #893
- Cache failed capabilities lookups for shorter amounts of time #890
- Fix highlight notifications for unencrypted rooms #891
- Document checking crypto state before using
hasUnverifiedDevices
#889 - Add logging to sync startup path #888
- Track e2e highlights better, particularly in 'Mentions Only' rooms #886
- support both the incorrect and correct MAC methods #882
- Refuse to set forwards pagination token on live timeline #885
- Degrade
IndexedDBStore
back to memory only on failure #884 - Refuse to link live timelines into the forwards/backwards position when either is invalid #877
- Key backup logging improvements #883
- Don't assume aborts are always from txn.abort() #880
- Add a bunch of logging #878
- Refuse splicing the live timeline into a broken position #873
- Add existence check to local storage based crypto store #872
Changes in 1.0.4 (2019-04-08)
- Hotfix: more logging and potential fixes for timeline corruption issue, see ticket element-hq/element-web#8593.
Changes in 1.0.3 (2019-04-01)
- Add existence check to local storage based crypto store #874
Changes in 1.0.3-rc.1 (2019-03-27)
- Add IndexedDB existence checks #871
- Emit sync errors for capturing by clients #869
- Add functions for getting room upgrade history and leaving those rooms #868
- Clarify the meaning of 'real name' for contribution #867
- Remove
sessionStore
tocryptoStore
migration path #865 - Add debugging for spurious room version warnings #866
- Add investigation notes for browser storage #864
- make sure resolve object is defined before calling it #862
- Rename
MatrixInMemoryStore
toMemoryStore
#861 - Use Buildkite for CI #859
- only create one session at a time per device #857
Changes in 1.0.2 (2019-03-18)
- No changes since rc.1
Changes in 1.0.2-rc.1 (2019-03-13)
- Use modern Yarn version on Travis CI #858
- Switch to
yarn
for dependency management #856 - More key request fixes #855
- Calculate encrypted notification counts #851
- Update dependencies #854
- make sure key requests get sent #850
- Use 'ideal' rather than 'exact' for deviceid #852
- handle partially-shared sessions better #848
Changes in 1.0.1 (2019-03-06)
- No changes since rc.2
Changes in 1.0.1-rc.2 (2019-03-05)
Changes in 1.0.1-rc.1 (2019-02-28)
- Fix "e is undefined" masking the original error in MegolmDecryption #847
Changes in 1.0.0 (2019-02-14)
- Try again to commit package-lock.json #841
Changes in 1.0.0-rc.2 (2019-02-14)
- Release script: commit package-lock.json #839
- Add method to force re-check of key backup #840
- Fix: dont check for unverified devices in left members #838
Changes in 1.0.0-rc.1 (2019-02-08)
- change hex SAS verification to decimal and emoji #837
- Trust on decrypt #836
- Always track our own devices #835
- Make linting rules more consistent #834
- add method to room to check for unverified devices #833
- Merge redesign into develop #831
- Supporting infrastructure for educated decisions on when to upgrade rooms #830
- Include signature info for unknown devices #826
- Flag v2 rooms as "safe" #828
- Update ESLint #821
Changes in 0.14.3 (2019-01-22)
- No changes since rc.1
Changes in 0.14.3-rc.1 (2019-01-17)
- Merge develop into experimental #815
- Add a getAllEndToEndSessions to crypto store #812
- T3chguy/fix displayname logic #668
- Contributing: Note that rebase lets you mass signoff commits #814
- take into account homoglyphs when calculating similar display names #672
- Emit for key backup failures #809
- emit oldEventId on "updatePendingEvent" #646
- Add getThirdpartyUser to base api #589
- Support custom status messages #805
- Extra checks to avoid release script blowing up mid-process. #749
- Move glob regex utilities out of the pushprocessor and into a more generic place #800
Changes in 0.14.2 (2018-12-10)
- No changes since rc.1
Changes in 0.14.2-rc.1 (2018-12-06)
- fix some assertions in e2e backup unit test #794
- Config should be called with auth #798
- Don't re-establish sessions with unknown devices #792
- e2e key backups #684
- WIP: online incremental megolm backups #595
- Support for e2e key backups #736
- Passphrase Support for e2e backups #786
- Add 'getSsoLoginUrl' function #783
- Fix: don't set the room name to null when heroes are missing. #784
- Handle crypto db version upgrades #785
- Restart broken Olm sessions #780
- Use the last olm session that got a message #776
Changes in 0.14.1 (2018-11-22)
- Warning when crypto DB is too new to use.
Changes in 0.14.0 (2018-11-19)
- No changes since rc.1
Changes in 0.14.0-rc.1 (2018-11-15)
- js-sdk now uses Olm 3.0. Apps using Olm must update to 3.0 to continue using Olm with the js-sdk. The js-sdk will call Olm's init() method when the client is started.
- Prevent messages from being sent if other messages have failed to send #781
- A unit test for olm #777
- Set access_token and user_id after login in with username and password. #778
- Add function to get currently joined rooms. #779
- Remove the request-only stuff we don't need anymore #775
- Manually construct query strings for browser-request instances #770
- Fix: correctly check for crypto being present #769
- Update babel-eslint to 8.1.1 #768
- Support
request
in the browser and support supplying servers to try in joinRoom() #764 - loglevel should be a normal dependency #767
- Stop devicelist when client is stopped #766
- Update to WebAssembly-powered Olm #743
- Logging lib. Fixes #332 #763
- Use new stop() method on matrix-mock-request #765
Changes in 0.13.1 (2018-11-14)
- Add function to get currently joined rooms. #779
Changes in 0.13.0 (2018-11-15)
MatrixClient::login
now sets clientaccess_token
anduser_id
following successful login with username and password.
Changes in 0.12.1 (2018-10-29)
- No changes since rc.1
Changes in 0.12.1-rc.1 (2018-10-24)
- Add repository type to package.json to make it valid #762
- Add getMediaConfig() #761
- add new examples, to be expanded into a post #739
Changes in 0.12.0 (2018-10-16)
- No changes since rc.1
Changes in 0.12.0-rc.1 (2018-10-11)
- If js-sdk finds data in the store that is incompatible with the options currently being used, it will emit sync state ERROR with an error of type InvalidStoreError. It will also stop trying to sync in this situation: the app must stop the client and then either clear the store or change the options (in this case, enable or disable lazy loading of members) and then start the client again.
- never replace /sync'ed memberships with OOB ones #760
- Don't fail to start up if lazy load check fails #759
- Make e2e work on Edge #754
- throw error with same name and message over idb worker boundary #758
- Default to a room version of 1 when there is no room create event #755
- Silence bluebird warnings #757
- allow non-ff merge from release branch into master #750
- Reject with the actual error on indexeddb error #751
- Update mocha to v5 #744
- disable lazy loading for guests as they cant create filters #748
- Revert "Add getMediaLimits to client" #745
Changes in 0.11.1 (2018-10-01)
- No changes since rc.1
Changes in 0.11.1-rc.1 (2018-09-27)
- make usage of hub compatible with latest version (2.5) #747
- Detect when lazy loading has been toggled in client.startClient #746
- Add getMediaLimits to client #644
- Split npm start into an init and watch script #742
- Revert "room name should only take canonical alias into account" #738
- fix display name disambiguation with LL #737
- Introduce Room.myMembership event #735
- room name should only take canonical alias into account #733
- state events from context response were not wrapped in a MatrixEvent #732
- Reduce amount of promises created when inserting members #724
- dont wait for LL members to be stored to resolve the members #726
- RoomState.members emitted with wrong argument order for OOB members #728
Changes in 0.11.0 (2018-09-10)
- v0.11.0-rc.1 introduced some breaking changes - see the respective release notes.
No changes since rc.1
Changes in 0.11.0-rc.1 (2018-09-07)
- Support for lazy loading members. This should improve performance for
users who joined big rooms a lot. Pass to
lazyLoadMembers = true
option when callingstartClient
.
MatrixClient::startClient
now returns a Promise. No method should be called on the client before that promise resolves. Before this method didn't return anything.- A new
CATCHUP
sync state, emitted byMatrixClient#"sync"
and returned byMatrixClient::getSyncState()
, when doing initial sync after theERROR
state. SeeMatrixClient
documentation for details. RoomState::maySendEvent('m.room.message', userId)
&RoomState::maySendMessage(userId)
do not check the membership of the user anymore, only the power level. To check if the syncing user is allowed to write in a room, useRoom::maySendMessage()
asRoomState
is not always aware of the syncing user's membership anymore, in case lazy loading of members is enabled.
- Only emit CATCHUP if recovering from conn error #727
- Fix docstring for sync data.error #725
- Re-apply "Don't rely on members to query if syncing user can post to room" #723
- Revert "Don't rely on members to query if syncing user can post to room" #721
- Don't rely on members to query if syncing user can post to room #717
- Fixes for room.guessDMUserId #719
- Fix filepanel also filtering main timeline with LL turned on. #716
- Remove lazy loaded members when leaving room #711
- Fix: show spinner again while recovering from connection error #702
- Add method to query LL state in client #714
- Fix: also load invited members when lazy loading members #707
- Pass through function to discard megolm session #704
Changes in 0.10.9 (2018-09-03)
- No changes since rc.2
Changes in 0.10.9-rc.2 (2018-08-31)
- Fix for "otherMember.getAvatarUrl is not a function" #708
Changes in 0.10.9-rc.1 (2018-08-30)
- Fix DM avatar #706
- Lazy loading: avoid loading members at initial sync for e2e rooms #699
- Improve setRoomEncryption guard against multiple m.room.encryption st… #700
- Revert "Lazy loading: don't block on setting up room crypto" #698
- Lazy loading: don't block on setting up room crypto #696
- Add getVisibleRooms() #695
- Add wrapper around getJoinedMemberCount() #697
- Api to fetch events via /room/.../event/.. #694
- Support for room upgrades #693
- Lazy loading of room members #691
Changes in 0.10.8 (2018-08-20)
- No changes since rc.1
Changes in 0.10.8-rc.1 (2018-08-16)
- Add getVersion to Room #689
- Add getSyncStateData() #680
- Send sync error to listener #679
- make sure room.tags is always a valid object to avoid crashes #675
- Fix infinite spinner upon joining a room #673
Changes in 0.10.7 (2018-07-30)
- No changes since rc.1
Changes in 0.10.7-rc.1 (2018-07-24)
- encrypt for invited users if history visibility allows. #666
Changes in 0.10.6 (2018-07-09)
- No changes since rc.1
Changes in 0.10.6-rc.1 (2018-07-06)
- Expose event decryption error via Event.decrypted event #665
- Add decryption error codes to base.DecryptionError #663
Changes in 0.10.5 (2018-06-29)
- No changes since rc.1
Changes in 0.10.5-rc.1 (2018-06-21)
- fix auth header and filename=undefined #659
- allow setting the output device for webrtc calls #650
- arguments true and false are actually invalid #596
- fix typo where
headers
was not being used and thus sent wrong content-type #643 - fix some documentation typos #642
Changes in 0.10.4 (2018-06-12)
- No changes since rc.1
Changes in 0.10.4-rc.1 (2018-06-06)
- check whether notif level is undefined, because
0
is falsey #651
Changes in 0.10.3 (2018-05-25)
- No changes since v0.10.3-rc.1
Changes in 0.10.3-rc.1 (2018-05-24)
The deprecated 'callback' parameter has been removed from MatrixBaseApis.deactivateAccount
- Add
erase
option to deactivateAccount #649 - Emit Session.no_consent when M_CONSENT_NOT_GIVEN received #647
Changes in 0.10.2 (2018-04-30)
- No changes from rc.1
Changes in 0.10.2-rc.1 (2018-04-25)
- Ignore inserts of dup inbound group sessions, pt 2 #641
- Ignore inserts of duplicate inbound group sessions #639
- Log IDB errors #638
- Remove not very useful but veryv spammy log line #632
- Switch event type to m.sticker. #628
Changes in 0.10.1 (2018-04-12)
- Log IDB errors #638
- Ignore inserts of duplicate inbound group sessions #639
- Ignore inserts of dup inbound group sessions, pt 2 #641
Changes in 0.10.0 (2018-04-11)
- No changes
Changes in 0.10.0-rc.2 (2018-04-09)
- Add wrapper for group join API
- Add wrapped API to set group join_policy
Changes in 0.10.0-rc.1 (2018-03-19)
- Fix duplicated state events in timeline from peek #630
- Create indexeddb worker when starting the store #627
- Fix indexeddb logging #626
- Don't do /keys/changes on incremental sync #625
- Don't mark devicelist dirty unnecessarily #623
- Cache the joined member count for a room state #619
- Fix JS doc #618
- Precompute push actions for state events #617
- Fix bug where global "Never send to unverified..." is ignored #616
- Intern legacy top-level 'membership' field #615
- Don't synthesize RR for m.room.redaction as causes the RR to go missing. #598
- Make Events create Dates on demand #613
- Stop cloning events when adding to state #612
- De-dup code: use the initialiseState function #611
- Create sentinel members on-demand #610
- Some more doc on how sentinels work #609
- Migrate room encryption store to crypto store #597
- add parameter to getIdentityServerUrl to strip the protocol for invites #600
- Move Device Tracking Data to Crypto Store #594
- Optimise pushprocessor #591
- Set event error before emitting #592
- Add event type for stickers [WIP] #590
- Migrate inbound sessions to cryptostore #587
- Disambiguate names if they contain an mxid #588
- Check for sessions in indexeddb before migrating #585
- Emit an event for crypto store migration #586
- Supporting fixes For making UnknownDeviceDialog not pop up automatically #575
- Move sessions to the crypto store #584
- Change crypto store transaction API #582
- Add some missed copyright notices #581
- Move Olm account to IndexedDB #579
- Fix logging of DecryptionErrors to be more useful #580
- [BREAKING] Change the behaviour of the unverfied devices blacklist flag #568
- Support set_presence=offline for syncing #557
- Consider cases where the sender may not redact their own event #556
Changes in 0.9.2 (2017-12-04)
Changes in 0.9.1 (2017-11-17)
- Fix the force TURN option #577
Changes in 0.9.0 (2017-11-15)
Changes in 0.9.0-rc.1 (2017-11-10)
- Modify addRoomToGroup to allow setting isPublic, create alias updateGroupRoomAssociation #567
- Expose more functionality of pushprocessor #565
- Function for working out notif trigger permission #566
- keep track of event ID and timestamp of decrypted messages #555
- Fix notifEvent computation #564
- Fix power level of sentinel members #563
- don't try to decrypt a redacted message (fixes element-hq/element-web#3744) #554
- Support room notifs #562
- Fix the glob-to-regex code #558
Changes in 0.8.5 (2017-10-16)
- Make unknown pushrule conditions not match #559
Changes in 0.8.5-rc.1 (2017-10-13)
- Implement wrapper API for removing a room from a group #553
- Fix typo which resulted in stuck key download requests #552
- Store group when it's created #549
- Luke/groups remove rooms users from summary #548
- Clean on prepublish #546
- Implement wrapper APIs for adding rooms to group summary #545
Changes in 0.8.4 (2017-09-21)
- Fix build issue
Changes in 0.8.3 (2017-09-20)
- No changes
Changes in 0.8.3-rc.1 (2017-09-19)
- consume trailing slash when creating Matrix Client in HS and IS urls #526
- Add ignore users API #539
- Upgrade to jsdoc 3.5.5 #540
- Make re-emitting events much more memory efficient #538
- Only re-emit events from Event objects if needed #536
- Handle 'left' users in the deviceList mananagement #535
- Factor out devicelist integration tests to a separate file #534
- Refactor sync._sync as an async function #533
- Add es6 to eslint environments #532
Changes in 0.8.2 (2017-08-24)
- Handle m.call.* events which are decrypted asynchronously #530
- Re-emit events from, er, Event objects #529
Changes in 0.8.1 (2017-08-23)
- [No changes]
Changes in 0.8.1-rc.1 (2017-08-22)
- Fix error handling in interactive-auth #527
- Make lots of OlmDevice asynchronous #524
- Make crypto.decryptMessage return decryption results #523
Changes in 0.8.0 (2017-08-15)
In order to support a move to a more scalable storage backend, we need to make a number of the APIs related end-to-end encryption asynchronous.
This release of the JS-SDK includes the following changes which will affect applications which support end-to-end encryption:
-
MatrixClient
now provides a new (asynchronous) method,initCrypto
. Applications which support end-to-end encryption must call this method (and wait for it to complete) before callingstartClient
, to give the crypto layer a chance to initialise. -
The following APIs have been changed to return promises:
MatrixClient.getStoredDevicesForUser
MatrixClient.getStoredDevice
MatrixClient.setDeviceVerified
MatrixClient.setDeviceBlocked
MatrixClient.setDeviceKnown
MatrixClient.getEventSenderDeviceInfo
MatrixClient.isEventSenderVerified
MatrixClient.importRoomKeys
Applications using the results of any of the above methods will need to be updated to wait for the result of the promise.
-
MatrixClient.listDeviceKeys
has been removed altogether. It's been deprecated for some time. Applications using it should instead be changed to useMatrixClient.getStoredDevices
, which is similar but returns its results in a slightly different format.
- Make bits of
olmlib
asynchronous #521 - Make some of DeviceList asynchronous #520
- Make methods in crypto/algorithms async #519
- Avoid sending unencrypted messages in e2e room #518
- Make tests wait for syncs to happen #517
- Make a load of methods in the 'Crypto' module asynchronous #510
- Set
rawDisplayName
touserId
if membership hasdisplayname=null
#515 - Refactor handling of crypto events for async #508
- Let event decryption be asynchronous #509
- Transform
async
functions to bluebird promises #511 - Add more group APIs #512
- Retrying test: wait for localEchoUpdated event #507
- Fix member events breaking on timeline reset, 2 #504
- Make bits of the js-sdk api asynchronous #503
- Yet more js-sdk test deflakification #499
- Fix racy 'matrixclient retrying' test #497
- Fix spamming of key-share-requests #495
- Add progress handler to
uploadContent
#500 - Switch matrix-js-sdk to bluebird #490
- Fix some more flakey tests #492
- make the npm test script windows-friendly #489
- Fix a bunch of races in the tests #488
- Fix early return in MatrixClient.setGuestAccess #487
- Remove testUtils.failTest #486
- Add test:watch script #485
- Make it possible to use async/await #484
- Remove m.new_device support #483
- Use access-token in header #478
- Sanity-check response from /thirdparty/protocols #482
- Avoid parsing plain-text errors as JSON #479
- Use external mock-request #481
- Fix some races in the tests #480
- Fall back to MemoryCryptoStore if indexeddb fails #475
- Fix load failure in firefox when indexedDB is disabled #474
- Fix a race in a test #471
- Avoid throwing an unhandled error when the indexeddb is deleted #470
- fix jsdoc #469
- Handle m.forwarded_room_key events #468
- Improve error reporting from indexeddbstore.clearDatabase #466
- Implement sharing of megolm keys #454
- Process received room key requests #449
- Send m.room_key_request events when we fail to decrypt an event #448
Changes in 0.7.13 (2017-06-22)
Changes in 0.7.12 (2017-06-19)
- No changes
Changes in 0.7.12-rc.1 (2017-06-15)
- allow setting iceTransportPolicy to relay through forceTURN option #462
Changes in 0.7.11 (2017-06-12)
- Add a bunch of logging around sending messages #460
Changes in 0.7.11-rc.1 (2017-06-09)
- Make TimelineWindow.load resolve quicker if we have the events #458
- Stop peeking when a matrix client is stopped #451
- Update README: Clarify how to install libolm #450
Changes in 0.7.10 (2017-06-02)
-
BREAKING CHANGE: The SDK no longer
require
solm
- instead it expects libolm to be provided as anOlm
global. This will only affect applications which use end-to-end encryption. See the README for details. -
indexeddb-crypto-store: fix db deletion #447
-
Load Olm from the global rather than requiring it. #446
Changes in 0.7.9 (2017-06-01)
- Initial framework for indexeddb-backed crypto store #445
- Factor out reEmit to a common module #444
- crypto/algorithms/base.js: Convert to es6 #443
- maySendRedactionForEvent for userId #435
- MatrixClient: add getUserId() #441
- Run jsdoc on a custom babeling of the source #442
- Add in a public api getStoredDevice allowing clients to get a specific device #439
Changes in 0.7.8 (2017-05-22)
- No changes
Changes in 0.7.8-rc.1 (2017-05-19)
- Attempt to rework the release-tarball-signing stuff #438
- ability to specify webrtc audio/video inputs for the lib to request #427
- make screen sharing call FF friendly :D #434
- Fix race in device list updates #431
- WebRTC: Support recvonly for video for those without a webcam #424
- Update istanbul to remove minimatch DoS Warning #422
- webrtc/call: Make it much less likely that callIds collide locally #423
- Automatically complete dummy auth #420
- Don't leave the gh-pages branch checked out #418
Changes in 0.7.7 (2017-04-25)
- No changes
Changes in 0.7.7-rc.1 (2017-04-21)
- Automatically complete dummy auth #420
Changes in 0.7.6 (2017-04-12)
- No changes
Changes in 0.7.6-rc.2 (2017-04-10)
Changes in 0.7.6-rc.1 (2017-04-07)
- Make indexeddb save after the first sync #414
- Make indexeddb startup faster #413
- Add ability to do indexeddb sync work in webworker #412
- Move more functionality to the indexeddb backend #409
- Indicate syncState ERROR after many failed /syncs #410
- Further reorganising of indexeddb sync code #407
- Change interface of IndexedDBStore: hide internals #406
- Don't be SYNCING until updating from the server #405
- Don't log the entire /sync response #403
- webrtc/call: Assign MediaStream to video element srcObject #402
- Fix undefined reference in http-api #400
- Add copyright header to event-timeline.js #382
- client: fix docs for user-scoped account_data events #397
- Add a CONTRIBUTING for js-sdk #399
- Fix leaking room state objects on limited sync responses #395
- Extend 'ignoreFailure' to be 'background' #396
- Add x_show_msisdn parameter to register calls #388
- Update event redaction to keep sender and origin_server_ts #394
- Handle 'limited' timeline responses in the SyncAccumulator #393
- Give a better error message if the HS doesn't support msisdn registeration #391
- Add getEmailSid #383
- Add m.login.email.identity support to UI auth #380
- src/client.js: Fix incorrect roomId reference in VoIP glare code #381
- add .editorconfig #379
- Store account data in the same way as room data #377
- Upload one-time keys on /sync rather than a timer #376
- Increase the WRITE_DELAY on database syncing #374
- Make deleteAllData() return a Promise #373
- Don't include banned users in the room name #372
- Support IndexedDB as a backing store #363
- Poll /sync with a short timeout while catching up #370
- Make test coverage work again #368
- Add docs to event #367
- Keep the device-sync token more up-to-date #366
- Fix race conditions in device list download #365
- Fix the unban method #364
- Spread out device verification work #362
- Clean up/improve e2e logging #361
- Fix decryption of events whose key arrives later #360
- Invalidate device lists when encryption is enabled in a room #359
- Switch from jasmine to mocha + expect + lolex #358
- Install source-map-support in each test #356
- searchMessageText: avoid setting keys=undefined #357
- realtime-callbacks: pass
global
asthis
#355 - Make the tests work without olm #354
- Tests: Factor out TestClient and use it in crypto tests #353
- Fix some lint #352
- Make a sig for source tarballs when releasing #351
- When doing a pre-release, don't bother merging to master and develop. #350
Changes in 0.7.5 (2017-02-04)
No changes from 0.7.5-rc.3
Changes in 0.7.5-rc.3 (2017-02-03)
Changes in 0.7.5-rc.2 (2017-02-03)
Changes in 0.7.5-rc.1 (2017-02-03)
- Support for blacklisting unverified devices, both per-room and globally #336
- track errors when events can't be sent #349
- Factor out device list management #346
- Support for warning users when unknown devices show up #335
- Enable sourcemaps in browserified distro #345
- Record all e2e room settings in localstorage #344
- Make Olm work with browserified js-sdk #340
- Make browserify a dev dependency #339
- Allow single line brace-style #338
- Turn on comma-dangle for function calls #333
- Add prefer-const #331
- Support for importing and exporting megolm sessions #326
- Fix linting on all tests #329
- Fix ESLint warnings and errors #325
- BREAKING CHANGE: Remove WebStorageStore #324
Changes in 0.7.4 (2017-01-16)
- Fix non-conference calling
Changes in 0.7.4-rc.1 (2017-01-13)
- Remove babel-polyfill #321
- Update build process for ES6 #320
- 'babel' is not a babel package anymore #319
- Add Babel for ES6 support #318
- Move screen sharing check/error #317
- release.sh: Bail early if there are uncommitted changes #316
Changes in 0.7.3 (2017-01-04)
- User presence list feature #310
- Allow clients the ability to set a default local timeout #313
- Add API to delete threepid #312
Changes in 0.7.2 (2016-12-15)
- Bump to Olm 2.0 #309
- Sanity check payload length before encrypting #307
- Remove dead _sendPingToDevice function #308
- Add setRoomDirectoryVisibilityAppService #306
- Update release script to do signed releases #305
- e2e: Wait for pending device lists #304
- Start a new megolm session when devices are blacklisted #303
- E2E: Download our own devicelist on startup #302
Changes in 0.7.1 (2016-12-09)
No changes
Changes in 0.7.1-rc.1 (2016-12-05)
- Avoid NPE when no sessionStore is given #300
- Improve decryption error messages #299
- Revert "Use native Array.isArray when available." #283
- Use native Array.isArray when available. #282
Changes in 0.7.0 (2016-11-18)
- Avoid a packetstorm of device queries on startup #297
- E2E: Check devices to share keys with on each send #295
- Apply unknown-keyshare mitigations #296
- distinguish unknown users from deviceless users #294
- Allow starting client with initialSyncLimit = 0 #293
- Make timeline-window _unpaginate public and rename to unpaginate #289
- Send a STOPPED sync updated after call to stopClient #286
- Fix bug in verifying megolm event senders #292
- Handle decryption of events after they arrive #288
- Fix examples. #287
- Add a travis.yml #278
- Encrypt all events, including 'm.call.*' #277
- Ignore reshares of known megolm sessions #276
- Log to the console on unknown session #274
- Make it easier for SDK users to wrap prevailing the 'request' function #273
Changes in 0.6.4 (2016-11-04)
- Change release script to pass version by environment variable
Changes in 0.6.4-rc.2 (2016-11-02)
- Add getRoomTags method to client #236
Changes in 0.6.4-rc.1 (2016-11-02)
- Bundled version of the JS SDK are no longer versioned along with source files in the dist/ directory. As of this release, they will be included in the release tarball, but not the source repository.
- More fixes to the release script #272
- Update the release process to use github releases #271
- Don't package the world when we release #270
- Add ability to set a filter prior to the first /sync #269
- Sign one-time keys, and verify their signatures #243
- Check for duplicate message indexes for group messages #241
- Rotate megolm sessions #240
- Check recipient and sender in Olm messages #239
- Consistency checks for E2E device downloads #237
- Support User-Interactive auth for delete device #235
- Utility to help with interactive auth #234
- Fix sync breaking when an invalid filterId is in localStorage #228
Changes in 0.6.3 (2016-10-12)
- Add a 'RECONNECTING' state to the sync states. This is an additional state between 'SYNCING' and 'ERROR', so most clients should not notice.
- Fix params getting replaced on register calls #233
- Fix potential 30s delay on reconnect #232
- uploadContent: Attempt some consistency between browser and node #230
- Fix error handling on uploadContent #229
- Fix uploadContent for node.js #226
- Don't emit ERROR until a keepalive poke fails #223
- Function to get the fallback url for interactive auth #224
- Revert "Handle the first /sync failure differently." #222
Changes in 0.6.2 (2016-10-05)
- Check dependencies aren't on develop in release.sh #221
- Fix checkTurnServers leak on logout #220
- Fix leak of file upload objects #219
- crypto: remove duplicate code #218
- Add API for 3rd party location lookup #217
- Handle the first /sync failure differently. #216
Changes in 0.6.1 (2016-09-21)
Changes in 0.6.0 (2016-09-21)
- Pull user device list on join #212
- Fix sending of oh_hais on bad sessions #213
- Support /publicRooms pagination #211
- Update the olm library version to 1.3.0 #205
- Comment what the logic in uploadKeys does #209
- Include keysProved and keysClaimed in the local echo for events we send. #210
- Check if we need to upload new one-time keys every 10 minutes #208
- Reset oneTimeKey to null on each loop iteration. #207
- Add getKeysProved and getKeysClaimed methods to MatrixEvent. #206
- Send a 'm.new_device' when we get a message for an unknown group session #204
- Introduce EventTimelineSet, filtered timelines and global notif timeline. #196
- Wrap the crypto event handlers in try/catch blocks #203
- Show warnings on to-device decryption fail #202
- s/Displayname/DisplayName/ #201
- OH HAI #200
- Share the current ratchet with new members #199
- Move crypto bits into a subdirectory #198
- Refactor event handling in Crypto #197
- Don't create Olm sessions proactively #195
- Use to-device events for key sharing #194
- README: callbacks deprecated #193
- Fix sender verification for megolm messages #192
- Use
ciphertext
instead ofbody
in megolm events #191 - Add debug methods to get the state of OlmSessions #189
- MatrixClient.getStoredDevicesForUser #190
- Olm-related cleanups #188
- Update to fixed olmlib #187
- always play audio out of the remoteAudioElement if it exists. #186
- Fix exceptions where HTMLMediaElement loads and plays race #185
- Reset megolm session when people join/leave the room #183
- Fix exceptions when dealing with redactions #184
Changes in 0.5.6 (2016-08-28)
- Put all of the megolm keys in one room message #182
- Reinstate device blocking for simple Olm #181
- support for unpacking megolm keys #180
- Send out megolm keys when we start a megolm session #179
- Change the result structure for ensureOlmSessionsForUsers #178
- Factor out a function for doing olm encryption #177
- Move DeviceInfo and DeviceVerification to separate module #175
- Make encryption asynchronous #176
- Added ability to set and get status_msg for presence. #167
- Megolm: don't dereference nullable object #174
- Implement megolm encryption/decryption #173
- Update our push rules when they come down stream #170
- Factor Olm encryption/decryption out to new classes #172
- Make DeviceInfo more useful, and refactor crypto methods to use it #171
- Move login and register methods into base-apis #169
- Remove defaultDeviceDisplayName from MatrixClient options #168
Changes in 0.5.5 (2016-08-11)
-
Add room.getAliases() and room.getCanonicalAlias
-
Add API calls
/register/email/requestToken
,/account/password/email/requestToken
and/account/3pid/email/requestToken
-
Add
User.currentlyActive
andUser.lastPresenceTs
events for changes in fields on the User object -
Add
logout
anddeactivateAccount
-
Make sure we actually stop the sync loop on logout #166
-
Zero is a valid power level #164
-
Verify e2e keys on download #163
-
Factor crypto stuff out of MatrixClient #162
-
Refactor device key upload #161
-
Wrappers for devices API #158
-
Add deactivate account function #160
-
client.listDeviceKeys: Expose device display name #159
-
Add
logout
#157 -
Fix email registration #156
-
Factor out MatrixClient methods to MatrixBaseApis #155
-
Fix some broken tests #154
-
make jenkins fail the build if the tests fail #153
-
deviceId-related fixes #152
-
/login, /register: Add device_id and initial_device_display_name #151
-
Support global account_data #150
-
Add more events to User #149
-
Add API calls for other requestToken endpoints #148
-
Add register-specific request token endpoint #147
-
Set a valid SPDX license identifier in package.json #139
-
Configure encryption on m.room.encryption events #145
-
Implement device blocking #146
-
Clearer doc for setRoomDirectoryVisibility #144
-
crypto: use memberlist to derive recipient list #143
-
Support for marking devices as unverified #142
-
Add Olm as an optionalDependency #141
-
Add room.getAliases() and room.getCanonicalAlias() #140
-
Change how MatrixEvent manages encrypted events #138
-
Catch exceptions when encrypting events #137
-
Support for marking devices as verified #136
-
Various matrix-client refactorings and fixes #134
Changes in 0.5.4 (2016-06-02)
- Correct fix for element-hq/element-web#1039
- Make release.sh work on OSX
Changes in 0.5.3 (2016-06-02)
- Add support for the openid interface #133
- Bugfix for HTTP upload content when running on node #129
- Ignore missing profile (displayname and avatar_url) fields on presence events, rather than overwriting existing valid profile data from membership events or elsewhere. Fixes element-hq/element-web#1039
Changes in 0.5.2 (2016-04-19)
- Track the absolute time that presence events are received, so that the relative lastActiveAgo value is meaningful. #128
- Refactor the addition of events to rooms #127
- Clean up test shutdown #126
- Add methods to get (and set) pushers #125
- URL previewing support #122
- Avoid paginating forever in private rooms #124
- Fix a bug where we recreated sync filters #123
- Implement HTTP timeouts in realtime #121
Changes in 0.5.1 (2016-03-30)
- Only count joined members for the member count in notifications. #119
- Add maySendEvent to match maySendStateEvent #118
Changes in 0.5.0 (2016-03-22)
BREAKING CHANGES:
opts.pendingEventOrdering
==end
is no longer supported in the arguments toMatrixClient.startClient()
. Instead we provide adetached
option, which puts pending events into a completely separate list in the Room, accessible viaRoom.getPendingEvents()
. #111
Other improvements:
- Log the stack when we get a sync error #109
- Refactor transmitted-messages code #110
- Add a method to the js sdk to look up 3pids on the ID server. #113
- Support for cancelling pending events #112
- API to stop peeking #114
- update store user metadata based on membership events rather than presence #116
- Include a counter in generated transaction IDs #115
- get/setRoomVisibility API #117
Changes in 0.4.2 (2016-03-17)
- Try again if a pagination request gives us no new messages #98
- Add a delay before we start polling the connectivity check endpoint #99
- Clean up a codepath that was only used for crypto messages #101
- Add maySendStateEvent method, ported from react-sdk (but fixed). #94
- Add Session.logged_out event #100
- make presence work when peeking. #103
- Add RoomState.mayClientSendStateEvent() #104
- Fix displaynames for member join events #108
Improvements:
- Check that
/sync
filters are correct before reusing them, and recreate them if not (matrix-org#85). - Fire a
Room.timelineReset
event when a room's timeline is reset by a gappy/sync
(matrix-org#87, matrix-org#93). - Make
TimelineWindow.load()
faster in the simple case of loading the live timeline (matrix-org#88). - Update room-name calculation code to use the name of the sender of the invite when invited to a room (matrix-org#89).
- Don't reset the timeline when we join a room after peeking into it (matrix-org#91).
- Fire
Room.localEchoUpdated
events as local echoes progress through their transmission process (matrix-org#95, matrix-org#97). - Avoid getting stuck in a pagination loop when the server sends us only messages we've already seen (matrix-org#96).
New methods:
- Add
MatrixClient.setPushRuleActions
to set the actions for a push notification rule (matrix-org#90) - Add
RoomState.maySendStateEvent
which determines if a given user has permission to send a state event (matrix-org#94)
BREAKING CHANGES:
RoomMember.getAvatarUrl()
andMatrixClient.mxcUrlToHttp()
now return the empty string when given anything other than an mxc:// URL. This ensures that clients never inadvertantly reference content directly, leaking information to third party servers. TheallowDirectLinks
option is provided if the client wants to allow such links.- Add a 'bindEmail' option to register()
Improvements:
- Support third party invites
- More appropriate naming for third party invite rooms
- Poll the 'versions' endpoint to re-establish connectivity
- Catch exceptions when syncing
- Room tag support
- Generate implicit read receipts
- Support CAS login
- Guest access support
- Never return non-mxc URLs by default
- Ability to cancel file uploads
- Use the Matrix C/S API v2 with r0 prefix
- Account data support
- Support non-contiguous event timelines
- Support new unread counts
- Local echo for read-receipts
New methods:
- Add method to fetch URLs not on the home or identity server
- Method to get the last receipt for a user
- Method to get all known users
- Method to delete an alias
-
MatrixClient.getAvatarUrlForMember
has been removed and replaced withRoomMember.getAvatarUrl
. Arguments remain the same except the homeserver URL must now be supplied fromMatrixClient.getHomeserverUrl()
.// before var url = client.getAvatarUrlForMember(member, width, height, resize, allowDefault) // after var url = member.getAvatarUrl(client.getHomeserverUrl(), width, height, resize, allowDefault)
-
MatrixClient.getAvatarUrlForRoom
has been removed and replaced withRoom.getAvatarUrl
. Arguments remain the same except the homeserver URL must now be supplied fromMatrixClient.getHomeserverUrl()
.// before var url = client.getAvatarUrlForRoom(room, width, height, resize, allowDefault) // after var url = room.getAvatarUrl(client.getHomeserverUrl(), width, height, resize, allowDefault)
-
s/Room.getMembersWithMemership/Room.getMembersWithMem
bership/g
New methods:
- Added support for sending receipts via
MatrixClient.sendReceipt(event, receiptType, callback)
andMatrixClient.sendReadReceipt(event, callback)
. - Added support for receiving receipts via
Room.getReceiptsForEvent(event)
andRoom.getUsersReadUpTo(event)
. Receipts can be directly added to aRoom
usingRoom.addReceipt(event)
though theMatrixClient
does this for you. - Added support for muting local video and audio via the new methods
MatrixCall.setMicrophoneMuted()
,MatrixCall.isMicrophoneMuted(muted)
,MatrixCall.isLocalVideoMuted()
andMatrix.setLocalVideoMuted(muted)
. - Added experimental support for screen-sharing in Chrome via
MatrixCall.placeScreenSharingCall(remoteVideoElement, localVideoElement)
. - Added ability to perform server-side searches using
MatrixClient.searchMessageText(opts)
andMatrixClient.search(opts)
.
Improvements:
- Improve the performance of initial sync processing from
O(n^2)
toO(n)
. Room.name
will now take into accountm.room.canonical_alias
events.MatrixClient.startClient
now takes an Objectopts
rather than a Number in a backwards-compatible way. Thisopts
allows syncing configuration options to be specified includingincludeArchivedRooms
andresolveInvitesToProfiles
.Room
objects which represent room invitations will now have state populated frominvite_room_state
if it is included in them.room.member
event.Room.getAvatarUrl
will now take into accountm.room.avatar
events.
Bug fixes:
- Null pointer fixes for VoIP calling and push notification processing.
- Set the
Content-Type
toapplication/octet-stream
in the event that the file object has notype
.
New methods:
- Added
MatrixClient.getCasServer()
which calls through to the HTTP endpoint/login/cas
. - Added
MatrixClient.loginWithCas(ticket, service)
which logs in with the typem.login.cas
. - Added
MatrixClient.getHomeserverUrl()
which returns the URL passed in the constructor. - Added
MatrixClient.getIdentityServerUrl()
which returns the URL passed in the constructor. - Added
getLastModifiedTime()
toRoomMember
,RoomState
andUser
objects. This makes it easier to see if the object in question has changed, which can be used to improve performance by only rendering when these objects change.
BREAKING CHANGES
MatrixClient.joinRoom
has changed from(roomIdOrAlias, callback)
to(roomIdOrAlias, opts, callback)
.
Bug fixes:
- The
Content-Type
of file uploads is now explicitly set, without relying on the browser to do it for us.
Improvements:
- The
MatrixScheduler.RETRY_BACKOFF_RATELIMIT
function will not retry when the response is a 400,401,403. - The text returned from a room invite now includes who the invite was from.
- There is now a try/catch block around the
request
function which will reject/errback appropriately if an exception is thrown synchronously in it.
New methods:
MatrixClient.createAlias(alias, roomId)
MatrixClient.getRoomIdForAlias(alias)
MatrixClient.sendNotice(roomId, body, txnId, callback)
MatrixClient.sendHtmlNotice(roomId, body, htmlBody, callback)
Modified methods:
MatrixClient.joinRoom(roomIdOrAlias, opts)
whereopts
can include asyncRoom: true|false
flag to control whether a room initial sync is performed after joining the room.MatrixClient.getAvatarUrlForMember
has a new last argallowDefault
which returns the default identicon URL iftrue
.MatrixClient.getAvatarUrlForRoom
has a new last argallowDefault
which is passed through to the default identicon generation forgetAvatarUrlForMember
.
BREAKING CHANGES:
MatrixClient.setPowerLevel
now expects aMatrixEvent
and not anObject
for theevent
parameter.
New features:
- Added
EventStatus.QUEUED
which is set on an event when it is waiting to be sent by the scheduler and there are other events in front. - Added support for processing push rules on an event. This can be obtained by
calling
MatrixClient.getPushActionsForEvent(event)
. - Added WebRTC support. Outbound calls can be made via
call = global.createNewMatrixCall(MatrixClient, roomId)
followed bycall.placeVoiceCall()
orcall.placeVideoCall(remoteEle, localEle)
. Inbound calls will be received via the event"Call.incoming"
which provides a call object which can be followed withcall.answer()
orcall.hangup()
. - Added the ability to upload files to the media repository.
- Added the ability to change the client's password.
- Added the ability to register with an email via an identity server.
- Handle presence events by updating the associated
User
object. - Handle redaction events.
- Added infrastructure for supporting End-to-End encryption. E2E is NOT available in this version.
New methods:
MatrixClient.getUser(userId)
MatrixClient.getPushActionsForEvent(event)
MatrixClient.setPassword(auth, newPassword)
MatrixClient.loginWithSAML2(relayState, callback)
MatrixClient.getAvatarUrlForMember(member, w, h, method)
MatrixClient.mxcUrlToHttp(url, w, h, method)
MatrixClient.getAvatarUrlForRoom(room, w, h, method)
MatrixClient.uploadContent(file, callback)
Room.getMembersWithMembership(membership)
MatrixScheduler.getQueueForEvent(event)
MatrixScheduler.removeEventFromQueue(event)
$DATA_STORE.setSyncToken(token)
$DATA_STORE.getSyncToken()
Crypto infrastructure (crypto is NOT available in this version):
global.CRYPTO_ENABLED
MatrixClient.isCryptoEnabled()
MatrixClient.uploadKeys(maxKeys)
MatrixClient.downloadKeys(userIds, forceDownload)
MatrixClient.listDeviceKeys(userId)
MatrixClient.setRoomEncryption(roomId, config)
MatrixClient.isRoomEncrypted(roomId)
New classes:
MatrixCall
WebStorageStore
- WIP; unstableWebStorageSessionStore
- WIP; unstable
Bug fixes:
- Member name bugfix: Fixed an issue which prevented
RoomMember.name
being disambiguated if there was exactly 1 other person with the same display name. - Member name bugfix: Disambiguate both clashing display names with user IDs in the event of a clash.
- Room state bugfix: Fixed a bug which incorrectly overwrote power levels locally for a room.
- Room name bugfix: Ignore users who have left the room when determining a room name.
- Events bugfix: Fixed a bug which prevented the
sender
andtarget
properties from being set.
BREAKING CHANGES:
Room.calculateRoomName
is now private. UseRoom.recalculate
instead, and access the calculated name viaRoom.name
.new MatrixClient(...)
no longer creates aMatrixInMemoryStore
ifopts.store
is not specified. Instead, thecreateClient
global function creates it and passes it to the constructor. This change will not affect users who have always usedcreateClient
to create aMatrixClient
."Room"
events will now be emitted when the Room has finished being populated with state rather than at the moment of creation. This will fire when the SDK encounters a room it doesn't know about (just arrived from the event stream; e.g. a room invite) and will also fire after syncing room state (e.g. after calling joinRoom).MatrixClient.joinRoom
now returns aRoom
object when resolved, not an object with aroom_id
property.MatrixClient.scrollback
now expects aRoom
arg instead of aroom_id
andfrom
token. Construct anew Room(roomId)
if you want to continue using this directly, then set the pagination token usingroom.oldState.paginationToken = from
. It now resolves to aRoom
object instead of the raw HTTP response.
New properties:
User.events
RoomMember.events
New methods:
Room.hasMembershipState(userId, membership)
MatrixClient.resendEvent(event, room)
New features:
- Local echo. When you send an event using the SDK it will immediately be
added to
Room.timeline
with theevent.status
ofEventStatus.SENDING
. When the event is finally sent, this status will be removed. - Not sent status. When an event fails to send using the SDK, it will have the
event.status
ofEventStatus.NOT_SENT
. - Retries. If events fail to send, they will be automatically retried.
- Manual resending. Events which failed to send can be passed to
MatrixClient.resendEvent(event, room)
to resend them. - Queueing. Messages sent in quick succession will be queued to preserve the order in which they were submitted.
- Room state is automatcally synchronised when joining a room (including if another device joins a room).
- Scrollback. You can request earlier events in a room using
MatrixClient.scrollback(room, limit, callback)
.
Bug fixes:
- Fixed a bug which prevented the event stream from polling. Some devices will black hole requests when they hibernate, meaning that the callbacks will never fire. We now maintain a local timer to forcibly restart the request.