Commit Graph

176 Commits (7d14a4660748e39abffcd4b9c43fb6164aac7d21)

Author SHA1 Message Date
Timo Kösters 68cc743f2a
fix: use get_auth_chain method more often 3 years ago
Timo Kösters 0f8ecdc625
fix: state res fixes 3 years ago
Timo Kösters cfaa900e83
improvement: auth chain cache 3 years ago
Timo Kösters f5273f7eb1
improvement: upgrade ruma and implement blurhashes 3 years ago
Timo Kösters 0fcefa4125
fix: ruma 3 years ago
Timo Kösters e12b1ff863
improvement: locks 3 years ago
Timo Kösters e15e6d4405
improvement: efficient /sync, mutex for federation transactions 3 years ago
Timo Kösters 1c25492a7e
fix: stuck messages
Conduit did not send the event in /sync because of a race condition.
There is a brief moment in time where Conduit accepted the event, but
did not store it yet. So when the client /syncs it updates the since
token without sending the event. I hope I fixed it by significantly
shortening the race-condition period.
3 years ago
Timo Kösters ac0027756e
improvement: more efficient state res 3 years ago
Jonathan de Jong 9d4fa9a220 Sqlite 3 years ago
Timo Kösters 13c0beafa6 Merge branch 'lib-fix' into 'master'
Export conduits Config struct and fix clippy warnings

See merge request famedly/conduit!99
3 years ago
Devin Ragotzy 1bb84a8e2d Fix docs for fetch_and_handle_events 3 years ago
Devin Ragotzy 98f1480e2b
Remove auth_cache using a closure to fetch events in state-res 3 years ago
Timo Kösters 05821d6fd5
improvement: pdu cache, /sync cache 3 years ago
Devin Ragotzy 09a8737f24 Export conduits Config struct and fix clipp warningsy 3 years ago
Jonas Platte 808741bcb6
Remove unnecessary Option-wrapping and successive unwrapping 3 years ago
Jonas Platte b291e76572
Use try operator for Option more 3 years ago
Jonas Platte f3e630c064
Fix lots of clippy lints 3 years ago
Jonas Platte f6046871f4
Upgrade Ruma 3 years ago
Timo Kösters 67f9592b17
feat: /event_auth 3 years ago
Timo Kösters 3c9ea55938
feat: /state 3 years ago
Timo Kösters cd4bc520d8
improvement: feature flags for sled, rocksdb 3 years ago
Timo Kösters d0ee823254
feat: swappable database backend 3 years ago
Timo Kösters 5b5cc0574e
feat: implement /claim, handle to-device events 3 years ago
Gabriel Souza Franco 7db59c550f fix: also return successful PDUs in /send/:txnId 3 years ago
Timo Kösters daa1fc90a7
fix: state resolution bugs 3 years ago
Timo Kösters e5c7119516
feat: forward federation errors to the client 3 years ago
Timo Kösters 989d843c40
fix: unauthorized pdus will be responded to with FORBIDDEN 3 years ago
Timo Kösters 09157b2096
improvement: federation get_keys and optimize signingkey storage
- get encryption keys over federation
- optimize signing key storage
- rate limit parsing of bad events
- rate limit signature fetching
- dependency bumps
3 years ago
Timo Kösters ae41bc5067
fix: run state res with old current state again
I'm a bit torn on the "auth check based on the current state of the
room". It can mean multiple things:

1. The state of the room before the homeserver looked at the event at
all. But that means if a message event from a user arrives, but we
didn't see their join event before, we soft fail the message (even
though we would find the join event when going through the auth events
of the event and doing state res)

2. The state of the room after doing state-res with the event and our
previous room state. We need to do this state resolution to find the new
room state anyway, so we could just use the new room state for the auth
check. The problem is that if the incoming event is a membership leave
event, the new room state does not allow another leave event. This is
obviously the wrong option.

3. The state of the room after doing state-res with the state **before**
the event and our previous room state. This will mean a lot more
calculations because we have to run state-res again

We used 2. before and now use 1. again
3 years ago
Timo Kösters f62258ba35
improvement: bug fixes and refactors
- power level content override adds to the default event instead of
replacing it
- sending code refactored to make edus possible
- remove presence events when restarting conduit
- remove room_id field from read receipts over /sync
- handle incoming read receipts
- fix array bounds bug in server_server.rs
3 years ago
Jonas Platte a0457000ff
Upgrade Ruma 3 years ago
Timo Kösters cf94b8e712
improvement: uiaa works like in synapse 3 years ago
Jonas Platte 8bfaf09f37
Clean up reqwest::Response to http::Response conversion 3 years ago
Jonas Platte 2e1d7d12ca
Refactor usage of CanonicalJsonValue 3 years ago
Timo Kösters 58463bba93
feat: send invites over federation 3 years ago
Timo Kösters 226045ea4b
improvement: warning on misconfigured reverse proxy 3 years ago
Jonas Platte d8b484beed
Upgrade ruma 3 years ago
Timo Kösters 6e84d317b2
improvement: update ruma 3 years ago
Timo Kösters 1f84013b2a
feat: verify signatures for incoming requests 3 years ago
Timo Kösters 8c72909bb8 Merge branch 'tls-name' into 'master'
Validate TLS certificates according to Matrix spec

See merge request famedly/conduit!60
3 years ago
Timo Kösters 2f440e644d
fix: clippy 3 years ago
Timo Kösters 71ed1b295a
feat: /devices route 3 years ago
Gabriel Souza Franco ed253e236c chore: document FedDest, fix tests 3 years ago
Timo Kösters d4e0ba245b
fix: bug when fetching events over federation 3 years ago
Timo Kösters eedac4fd96
feat: make_join, send_join and /directory 3 years ago
Gabriel Souza Franco 7faa021ff5 chore: code formatting and cleanup 3 years ago
Gabriel Souza Franco b4c001de2f chore: cleanup string-based code in find_actual_destination 3 years ago
Gabriel Souza Franco 0b56589dce feat: add handling of tls cert for delegated hosts 3 years ago
Timo Kösters c1953efa6b
chore: code cleanup 3 years ago