Bruno Windels
|
1b8e481559
|
keys from backup need to be imported with import_session, not create
|
2020-09-17 17:59:02 +02:00 |
|
Bruno Windels
|
915925d6ee
|
don't throw when trying to restore session from backup, check sender key
|
2020-09-17 17:57:52 +02:00 |
|
Bruno Windels
|
5752cca69c
|
go back to bs58 and use other base64 decoder
as base-x isn't meant for base64
|
2020-09-17 17:56:05 +02:00 |
|
Bruno Windels
|
9d622434fb
|
integrate session backup with session class
|
2020-09-17 15:58:46 +02:00 |
|
Bruno Windels
|
c9d8d40242
|
move ssss out of e2ee dir as not really e2ee related
|
2020-09-17 15:17:00 +02:00 |
|
Bruno Windels
|
33aa475e18
|
add function to create key from either passphrase or recovery key
|
2020-09-17 15:16:01 +02:00 |
|
Bruno Windels
|
092547bfc8
|
renaming
|
2020-09-17 14:20:36 +02:00 |
|
Bruno Windels
|
17fc249fa8
|
integrate session backup with room encryption and megolm decryption
|
2020-09-17 14:20:15 +02:00 |
|
Bruno Windels
|
3941af93d2
|
more impl of SessionBackup
|
2020-09-17 14:19:57 +02:00 |
|
Bruno Windels
|
fff8308259
|
first draft of SessionBackup
|
2020-09-17 12:34:39 +02:00 |
|
Bruno Windels
|
b7401a148c
|
some ssss cleanup
|
2020-09-17 12:33:57 +02:00 |
|
Bruno Windels
|
8204e942d9
|
first draft of reading a ssss secret
|
2020-09-17 11:39:40 +02:00 |
|
Bruno Windels
|
c44ab3e55e
|
derive ssss key from recovery key
|
2020-09-17 11:39:25 +02:00 |
|
Bruno Windels
|
7c4c266fe0
|
derive ssss key from passphrase
|
2020-09-17 11:39:07 +02:00 |
|
Bruno Windels
|
45c62eb0e5
|
common types and storage for ssss
|
2020-09-17 11:38:53 +02:00 |
|
Bruno Windels
|
12262f2824
|
actually use correct method to get all device ids for a user
|
2020-09-14 18:31:54 +02:00 |
|
Bruno Windels
|
3325f12092
|
remove devices not present in /keys/query response
|
2020-09-14 15:47:00 +02:00 |
|
Bruno Windels
|
a2f8731a23
|
Keep room key with earliest index
|
2020-09-14 15:47:00 +02:00 |
|
Bruno Windels
|
ab1fe711ad
|
implement room key sharing with operations store
|
2020-09-11 14:41:12 +02:00 |
|
Bruno Windels
|
bba53b3477
|
dont store duplicated key values for replay detection
|
2020-09-11 12:08:06 +02:00 |
|
Bruno Windels
|
e0d9d703b7
|
offload olm account creation in worker
|
2020-09-11 10:43:17 +02:00 |
|
Bruno Windels
|
78fecd003a
|
cleanup
|
2020-09-10 18:57:29 +02:00 |
|
Bruno Windels
|
af36c71a59
|
load worker in main and pass paths so it works both on compiled and non-compiled
|
2020-09-10 18:41:23 +02:00 |
|
Bruno Windels
|
de1cc0d739
|
abort decrypt requests when changing room
|
2020-09-10 17:43:01 +02:00 |
|
Bruno Windels
|
0bf1723d99
|
Worker WIP
|
2020-09-10 15:40:30 +01:00 |
|
Bruno Windels
|
fdbc5f3c1d
|
WIP worker work
|
2020-09-10 13:00:11 +02:00 |
|
Bruno Windels
|
94b0cfbd72
|
add prepareSync and afterPrepareSync steps to sync, run decryption in it
|
2020-09-10 12:11:43 +02:00 |
|
Bruno Windels
|
1c77c3b876
|
expose multi-step decryption from RoomEncryption, adjust room timeline
sync code hasn't been adjusted yet
|
2020-09-10 12:11:25 +02:00 |
|
Bruno Windels
|
7c1f9dbed0
|
split up megolm decryption so it can happen in multiple steps,see README
|
2020-09-10 12:05:53 +02:00 |
|
Bruno Windels
|
1f9d6191c2
|
this happens often when room is not tracked yet, so don't log
|
2020-09-08 18:32:51 +02:00 |
|
Bruno Windels
|
0ed2d14887
|
log OTK claim failures
|
2020-09-08 18:32:12 +02:00 |
|
Bruno Windels
|
4ca5ff9b9f
|
only load 50 olm sessions at once
|
2020-09-08 18:30:06 +02:00 |
|
Bruno Windels
|
10b5614fd9
|
m.dummy events don't have content
|
2020-09-08 18:27:49 +02:00 |
|
Bruno Windels
|
9a7abb1899
|
make logic more explicit
|
2020-09-08 18:27:35 +02:00 |
|
Bruno Windels
|
36a8ec0110
|
dont attempt to decrypt redacted events
this will show them as undecryptable for now though
|
2020-09-08 17:16:01 +02:00 |
|
Bruno Windels
|
773cb3420f
|
ignore duplicate curve25519 keys in /keys/query response
|
2020-09-08 17:14:23 +02:00 |
|
Bruno Windels
|
b653022a5a
|
do store our own device, otherwise need special case verifying own msgs
|
2020-09-08 15:25:36 +02:00 |
|
Bruno Windels
|
31d4b6f75d
|
send room keys to newly joined members in afterSyncCompleted stage
|
2020-09-08 14:38:27 +02:00 |
|
Bruno Windels
|
52c3c7c03d
|
support sending out room key in room encryption for newly joined members
|
2020-09-08 14:36:50 +02:00 |
|
Bruno Windels
|
7b35a3c46c
|
memberChanges is a map, not array
|
2020-09-08 14:23:38 +02:00 |
|
Bruno Windels
|
d184be2d22
|
rotate outbound megolm session when somebody leaves the room
|
2020-09-08 11:09:09 +02:00 |
|
Bruno Windels
|
2c5c3ac8e2
|
formatting
|
2020-09-08 10:53:02 +02:00 |
|
Bruno Windels
|
2b59c8bb7c
|
store ed25519 key from olm event rather than one in m.room_key payload
that's the docs/js-sdk do it, even though it probably
doesn't matter much as we verify the key anyway
|
2020-09-08 10:52:02 +02:00 |
|
Bruno Windels
|
40ed66dc5e
|
document return type
|
2020-09-08 10:51:45 +02:00 |
|
Bruno Windels
|
3e100ff5ec
|
ensure /keys/query devices have the keys we need
|
2020-09-08 10:51:01 +02:00 |
|
Bruno Windels
|
c32ac2c764
|
use decryption result to show message verification status in timeline
|
2020-09-08 10:50:39 +02:00 |
|
Bruno Windels
|
9137d5dcbb
|
make decryption algorithms return DecryptionResult
which contains curve25519 key and claimed ed25519 key as well as payload
|
2020-09-08 10:48:11 +02:00 |
|
Bruno Windels
|
fbb534fa16
|
add todo
|
2020-09-04 16:46:13 +02:00 |
|
Bruno Windels
|
9b771120e4
|
actually accept megolm decryption dep
|
2020-09-04 16:27:14 +02:00 |
|
Bruno Windels
|
dc0576f2db
|
cleanup
|
2020-09-04 15:31:45 +02:00 |
|